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

Sortowanie bąbelkowe

Object Storage Arubacloud
–1 głos
294 wizyt
pytanie zadane 9 listopada 2016 w C i C++ przez MiO Obywatel (1,310 p.)
otwarte ponownie 9 listopada 2016 przez draghan

Witam! Piszę program, który wylosuje kilka liczb  a następnie je uporządkuję. Kod:

#include <iostream>
#include <time.h>
#include <conio.h>

using namespace std;

int main()
{
	unsigned const int i = 10;
	int tab[i];
	double save;



	srand(time(NULL));


	cout << "Liczby przed sortowaniem: ";


	for (int k = 0; k <= i; k++)
	{

		cout << endl;
		tab[i] = rand();
		if (tab[i] == 0)
		{
			do
			{
				tab[i] = rand();
				cout << tab[i];
			} while (tab[i] != 0);
		}

		else
			cout << tab[i];
	}

	cout << endl;
	cout << endl;
	cout << "============" << endl;
	cout << endl;

	cout << "Liczby po sortowaniu: ";


	if (tab[i] > tab[i + 1])
	{
		cout << endl;
		save = tab[i + 1];
		tab[i + 1] = tab[i];
		tab[i] = save;
		cout << tab[i];
	}


	_getch();
}
 

 

3
komentarz 9 listopada 2016 przez niezalogowany
Cześć!
komentarz 9 listopada 2016 przez MiO Obywatel (1,310 p.)
Przepraszam bardzo zapomniałem xD

Chodzi o to że algorytm sortujacy wyrzuca tyloo 1 liczbę w dodatku  na minusie i nie wiem gdzie jest błąd. Liczba ta nie ma związku z losowanymi liczbami

1 odpowiedź

+1 głos
odpowiedź 9 listopada 2016 przez Myśliwy Gaduła (3,080 p.)
wybrane 9 listopada 2016 przez MiO
 
Najlepsza

#include <iostream>
#include <time.h>
#include <cstdlib>
#include <conio.h>

using namespace std;

int main()
{
    unsigned const int i = 10;
    int tab[i]; // tab[0] tab[1] tab[2] ... tab[8] tab[9]
    double save;
    srand(time(NULL));
    cout << "Liczby przed sortowaniem: ";

    //for (int k = 0; k <= i; k++) nie k<=i , bo wtedy wykona się 11 razy, do tego dla 0<=k<=10 , tab[k]:
    // tab[0] tab[1] tab[2] ... tab[9] tab[10] - tab[10] nie zostało zadeklarowane
    for (unsigned int k = 0; k < i; k++)
    {

        cout << endl;
        // tab[i] = rand(); tab[i] to to samo co tab[10]
        tab[k]=rand();
        //if (tab[i] == 0)
        if (tab[k] == 0)
        {
            do
            {
                //tab[i] = rand();
                tab[k] = rand();
                cout << tab[k];
            } //while (tab[i] != 0);
              while (tab[k] != 0);
        }

        else
            cout << //tab[i];
                    tab[k];
    }

    cout << endl;
    cout << endl;
    cout << "============" << endl;
    cout << endl;

    cout << "Liczby po sortowaniu: ";

 // if - instrukcja warunkowa wykonuje się tylko raz
 
 /* DO POPRAWY
    if (tab[i] > tab[i + 1])
    {
        cout << endl;
        save = tab[i + 1];
        tab[i + 1] = tab[i];
        tab[i] = save;
        cout << tab[i];
    }
*/


    _getch();
}

Jeśli deklarujesz jakąś zmienną albo stałą (tutaj stała "i" ), musisz zapamiętać do czego służy. Ja poprawiłem ci losowanie liczb do tablicy, ty popraw algorytm sortujący.

komentarz 9 listopada 2016 przez MiO Obywatel (1,310 p.)
Dzięki wielkie

Podobne pytania

0 głosów
1 odpowiedź 183 wizyt
pytanie zadane 8 stycznia 2023 w C i C++ przez Zuzan Początkujący (390 p.)
0 głosów
1 odpowiedź 535 wizyt
pytanie zadane 24 października 2021 w C i C++ przez pita Nowicjusz (180 p.)
0 głosów
1 odpowiedź 797 wizyt
pytanie zadane 2 lutego 2021 w C i C++ przez Kamirru9 Początkujący (300 p.)

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!

...