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

Ogromne liczby po sortowaniu.

Object Storage Arubacloud
0 głosów
291 wizyt
pytanie zadane 12 stycznia 2019 w C i C++ przez KonDZIKs Bywalec (2,770 p.)

Witam :)
Mam pytanie dlaczego po posortowaniu liczb są one wgl inne? :) Kod z sortowaniem pobrałem z odcinka 14.

#include <iostream>
#include <cstdlib>
#include <ctime>

using namespace std;

int rozmiar;
int* tab =new int [rozmiar];

void sortowanie(int *tablica, int n)
{
    for(int i=1; i<n; i++)
    {
        for(int j=n-1; j>=1; j--)
        {
            if
            (tab[j]<tab[j-1])
            {
                int bufor;
                bufor=tab[j-1];
                tab[j-1]=tab[j];
                tab[j]=bufor;
            }
        }
    }
}


int main()
{
    cout << "Podaj ilosc elemetow: ";
    cin >> rozmiar;
    cout <<"Podany rozmiar tablicy to: " << rozmiar<<endl;

    srand(time(NULL));

    for(int i=0; i<rozmiar; i++)
    {
        cout<<" " << rand()%101;

    }

    cout<<endl;
    sortowanie(tab, rozmiar);
    cout<<"Po posortowaniu:"<<endl;
    for(int i=0; i<rozmiar; i++)
    {
        cout<< tab[i]<<" ";
    }
    delete [] tab;
    return 0;
}

 

1 odpowiedź

0 głosów
odpowiedź 12 stycznia 2019 przez RafalS VIP (122,820 p.)
edycja 12 stycznia 2019 przez RafalS

Obstawiam, że przez niezainicjowaną długośc tablicy:

int rozmiar;
int* tab =new int [rozmiar];

rozmiar może wynosic np 951064 a może -54321, która dla zmiennej globalnej rozmiar będzie wynosić 0.

komentarz 12 stycznia 2019 przez KonDZIKs Bywalec (2,770 p.)
Rozumiem w takim razie dlaczego nie wykorzystuje ona wcześniejszego losowania?
1
komentarz 12 stycznia 2019 przez monika90 Pasjonat (22,940 p.)
rozmiar twojej tablicy jest równy zero, dokładnie ten sam problem był w twoim poprzednim pytaniu
komentarz 12 stycznia 2019 przez mokrowski Mędrzec (155,460 p.)

@RafalS,
Będzie wynosił dokładnie zero. Standard gwarantuje dla takich zmiennych "przed main()" inicjalizację zerem (tu rozmiar).

komentarz 12 stycznia 2019 przez KonDZIKs Bywalec (2,770 p.)
Czyli ze wystarczy tworzenie tablicy wrzucic do main'a?

 

@ Wrzucilem do main'a losuje i sortuje lecz nie te liczby ktore potrzeba. I nie ma juz liczb ujemnych.
komentarz 12 stycznia 2019 przez monika90 Pasjonat (22,940 p.)
jeszcze będziesz musiał coś do tej tablicy wpisać
komentarz 12 stycznia 2019 przez KonDZIKs Bywalec (2,770 p.)
int* tab;

tab new int [rozmiar];

O to chodziło?

Podobne pytania

0 głosów
0 odpowiedzi 77 wizyt
pytanie zadane 18 kwietnia 2020 w Java przez princeV Nowicjusz (140 p.)
–1 głos
1 odpowiedź 173 wizyt
pytanie zadane 10 lipca 2016 w JavaScript przez LCPGM Obywatel (1,550 p.)
0 głosów
1 odpowiedź 199 wizyt

92,556 zapytań

141,404 odpowiedzi

319,563 komentarzy

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

...