• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Modyfikacja sortowania przez wstawianie (malejące)

Object Storage Arubacloud
0 głosów
947 wizyt
pytanie zadane 23 listopada 2017 w C i C++ przez antek782 Początkujący (490 p.)

Witam,

Napisałem funkcję, która sortuje poprzez wstawianie, liczby rosnąco. Potrzebuję zmodyfikować tak, aby sortowało malejąco. Proszę o pomoc.

void wstawianie(int* tablica, int N)
{
    int i, j, tmp;
    for(i=1; i<N; i++)
    {
        // elementy o indeksach 0 do i-1 sa juz uporzadkowane

        tmp=tablica[i]; // wartosc i-tego elementu

        // przesuwanie elementow tablica[j]<=tmp
        j=i-1;
        while(j>=0 && porownaj(tablica[j],tmp))
        {
            tablica[j+1]=tablica[j];
            j--;
		}
        // wstawienie elementu (potrzebne jest dodanie 1 bo j bylo dekrementowane w linii 48)
        tablica[j+1]=tmp;
    }
}

 

1 odpowiedź

+1 głos
odpowiedź 23 listopada 2017 przez damianeqe Gaduła (4,380 p.)
Prawdopodobnie, zmiany będzie wymagała funkcja porównaj
komentarz 23 listopada 2017 przez antek782 Początkujący (490 p.)
int porownaj(int a, int b)
{
    return a>b;
}

 

1
komentarz 23 listopada 2017 przez damianeqe Gaduła (4,380 p.)
Eh, wydaje mi się że sam tego kodu nie napisałeś.

 

Funkcja porównaj powinna zwracać bool zamiast int'a. Teraz zwraca 1(true) jeżeli a jest większe od b. I jest to sortowanie rosnące. Więc żeby sortować malejąco wystarczy zmienić znak porównania.

Podobne pytania

0 głosów
1 odpowiedź 344 wizyt
pytanie zadane 13 czerwca 2018 w C i C++ przez Halpi Początkujący (300 p.)
+1 głos
1 odpowiedź 114 wizyt
pytanie zadane 12 grudnia 2021 w C i C++ przez WonderOfU Nowicjusz (160 p.)
–1 głos
2 odpowiedzi 499 wizyt

92,570 zapytań

141,422 odpowiedzi

319,643 komentarzy

61,959 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...