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

Sortowanie przez zliczanie C

Object Storage Arubacloud
0 głosów
546 wizyt
pytanie zadane 23 marca 2021 w C i C++ przez warzywko13 Użytkownik (840 p.)

Dzień dobry,

Mam następujący problem powyżej 2 liczb w programie pojawiają się krzaczki widoczne na screenie. Proszę o podpowiedź albo o dobry przykład jak sobie poradzić z tym.

Z góry dzięki za pomoc

#include <stdio.h>

int a[] = {2, 1, 4};
int b[] = {};
int n = sizeof(a) / sizeof(a[0]);

int main()
{
    int max = 0;

    for(int i=0; i<n; i++){
        if(a[i]>max){
            max=a[i];
        }
    }

    for(int i=0; i<n; i++){
        b[a[i]]++;

        printf("\nPosortowana tablica to:");
        for(int i=0; i<=max; i++){
            for(int j=1; j<=b[i]; j++){
                printf("%d ",  i);
            }
        }
    }

    return 0;
}

3 odpowiedzi

0 głosów
odpowiedź 24 marca 2021 przez j23 Mędrzec (194,920 p.)

Jaki ma rozmiar tablica b?

0 głosów
odpowiedź 26 marca 2021 przez warzywko13 Użytkownik (840 p.)

Poradziłem sobie. Jakby ktoś kiedyś potrzebował działający kod:

#include <stdio.h>
 
int A[] = {3, 6, 3, 2, 7, 1, 7, 1};
int n = sizeof(A) / sizeof(A[0]);
int Z[] = {};
 
int main()
{
    int max = 0;
 
    for(int i=0; i<n; i++){
        if(A[i]>max){
            max=A[i];
            Z[max] = 0;
        }
    }
 
    for(int i=0; i<n; i++){
        Z[A[i]]++;
 
    }

    for(int i=0; i<=max; i++){
        for(int j=1; j<=Z[i]; j++){
            printf("%d ",  i);
        }
    }
 
    return 0;
}

 

–1 głos
odpowiedź 23 marca 2021 przez MamFarta Użytkownik (740 p.)

Co masz na myśli mówiąc krzaczki?
Twój kod działa poprawnie, tj. dobrze sortuje twój zbiór liczb wejściowych, może po prostu nie przekompiliowałeś pliku ponownie?

Podobne pytania

0 głosów
1 odpowiedź 203 wizyt
0 głosów
1 odpowiedź 213 wizyt
pytanie zadane 9 czerwca 2018 w C i C++ przez WhiteDragon Początkujący (290 p.)
+1 głos
0 odpowiedzi 185 wizyt

92,584 zapytań

141,433 odpowiedzi

319,668 komentarzy

61,966 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!

...