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

Konsola wyświetla podczas liczenia, ale nie zapisuje danych pierwszej tablicy

Object Storage Arubacloud
+1 głos
118 wizyt
pytanie zadane 23 maja 2021 w C i C++ przez Arick720 Nowicjusz (180 p.)

Witam, problem tak jak w temacie najlepiej sobie odpalić program by to zobaczyć, i dlaczego tak jest?

A przy x = 100000 pierwsza wyświetla ,a drugiej nie sortuje, a w sumie na tej liczbie bardziej mi zalezy.

 

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

using namespace std;
void sortowanie (int tablica[], int x);
int main()
{
//Deklaracja zmiennych//
int x = 10000;
int tablica[x];
srand(time(NULL));
cout << "Tablica nieposortowana:" <<endl;
	for(int i = 0; i < x-1; i++)
	{
//Losowanie wartosci//
	tablica[i] = rand()%650 - 50;
	}
	for(int i = 0; i < x-1; i++)
	{
		cout << tablica[i] << endl;
	}
	cout << "Tablica posortowana: " << endl;
//Wykorzystanie funkcji//
	sortowanie(tablica, x);
	for(int i = 0; i<x-1; i++)
	{
//Wyswietlenie tablicy//
		cout << tablica[i] <<endl;
	
	}
}
//Funkcja sortujaca//
void sortowanie (int tablica[],int x)
{
int z;
int h = 0;
int f = 0;
int g = 0;
do
{
z=0;
for(int j = x-1; j >= 0; j--)
	{
	if (tablica[j-1] < tablica [j])
		{
		//Zamiana miejscami//
		int zamien;
		zamien = tablica [j];
		tablica[j] = tablica[j-1];
		tablica[j-1] = zamien;
		z=1;
		f++;
		}
	}
for(int j = 0; j < x-1; j++)
	{
	if (tablica[j] < tablica [j+1])
		{
		//Zamiana miejscami//
		int zamien;
		zamien = tablica [j+1];
		tablica[j+1] = tablica[j];
		tablica[j] = zamien;
		z=1;
		g++;
		}
	}
	h= f + g;
}
while(z==1);
//Ilosc zmian//
cout << "Sorotwanie wymagalo k zamian rowne: " << f << " " << g << " " << h <<" " << endl;
}

 

1 odpowiedź

+2 głosów
odpowiedź 24 maja 2021 przez TOM_CPP Pasjonat (22,640 p.)
edycja 24 maja 2021 przez TOM_CPP
  1. Nie dodałeś biblioteki iostream, więc kod nie mam prawa się skompilować.
  2. W standardzie C++ nie ma tablic typu VLA. Chociaż niektóre kompilatory na to pozwalają ( np. gcc ) to dla x = 1000000 program może się już wysypać. Jeżeli chcesz utworzyć tablicę dynamiczną powinieneś użyć std::vector<int> lub w ostateczności utworzyć ją przy pomocy operatora new.
  3. Kod funkcji sortującej jest trochę przekombinowany. Zobacz jak może to wyglądać (  std::vector jako tablica )
    void sort( vector<int>& data )
    {
        // simply bubble sort
        for( size_t i {0} ; i < data.size()-1 ; ++i )
        for( size_t j {0} ; j < data.size()-i-1 ; ++j )
        if( data[j] > data[j+1]) swap(data[j],data[j+1]);
    }

     

Podobne pytania

0 głosów
1 odpowiedź 292 wizyt
0 głosów
1 odpowiedź 301 wizyt
0 głosów
2 odpowiedzi 194 wizyt

92,576 zapytań

141,426 odpowiedzi

319,652 komentarzy

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

...