Niestety, nikt nie powie Ci czym jest FluxBB - musisz go poznać sam!
Nie jesteś zalogowany na forum.
Strony: 1
#include <iostream>
#include <time.h>
#include <windows.h>
using namespace std;
int ile;
clock_t start,stop;
double czas;
void sortowanie_babelkowe(int *tab, 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;
}
}
}
}
void quicksort(int *tablica, int lewy, int prawy)
{
int v=tablica[(lewy+prawy)/2];
int i,j,x;
i=lewy;
j=prawy;
do
{
while(tablica[i]<v) i++;
while(tablica[j]>v) j--;
if(i<=j)
{
x=tablica[i];
tablica[i]=tablica[j];
tablica[j]=x;
i++;
j--;
}
}
while(i<=j);
if(j>lewy) quicksort(tablica,lewy, j);
if(i<prawy) quicksort(tablica, i, prawy);
}
int main()
{
cout << "Porownanie czasow sortowania v.1" << endl;
cout<<"Ile losowych liczb w tablicy: ";
cin>>ile;
//dynamiczna alokacja tablicy
int *tablica;
tablica=new int [ile];
int *tablica2;
tablica2=new int [ile];
//inicjowanie generatora
srand(time(NULL));
//wczytywanie losowych liczb do tablicy
for(int i=0; i<ile; i++)
{
tablica[i] = rand()%100000+1;
}
//przepisanie tablicy do tablicy2
for(int i=0; i<ile; i++)
{
tablica2[i]=tablica[i];
}
/*
cout<<"Przed posortowaniem: "<<endl;
for(int i=0; i<ile; i++)
{
cout<<tablica2[i]<<" ";
}
*/
cout<<"Sortuje teraz babelkowo. Prosze czekac!"<<endl;
start = clock();
sortowanie_babelkowe(tablica,ile);
stop = clock();
czas = (double)(stop-start) / CLOCKS_PER_SEC;
cout<<endl<<"Czas sortowania babelkowego: "<<czas<<" s"<<endl;
cout<<endl<<"Sortuje teraz algorytmem quicksort. Prosze czekac!"<<endl;
start = clock();
quicksort(tablica2, 0, ile-1);
stop = clock();
czas = (double)(stop-start) / CLOCKS_PER_SEC;
cout<<endl<<"Czas sortowania quicksort: "<<czas<<" s"<<endl;
/*
cout<<"Po posortowaniu: "<<endl;
for(int i=0; i<ile; i++)
{
cout<<tablica[i]<<" ";
}
*/
delete [] tablica;
delete [] tablica2;
return 0;
}
Offline
Strony: 1
[ Wygenerowano w 0.016 sekund, wykonano 9 zapytań - Pamięć użyta: 486.21 kB (Maksimum: 536.3 kB) ]