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

sortowanie merge sort bez rekurencji (szybkie sortowanie)

Object Storage Arubacloud
0 głosów
446 wizyt
pytanie zadane 14 maja 2020 w Java przez Pawelixon2001 Nowicjusz (180 p.)
edycja 16 maja 2020 przez Pawelixon2001

Witam dzisiaj przedstawiam wam merge sort bez rekurencji

 

musisz wywołać metodę wstepMergeSort

private static int[] copy;
	
public static void wstepMergeSort(int tab[], int lewy, int prawy) {
	copy = new int[prawy+2];
	int rozmiar = 2;
	int wskaznik = lewy;
	while(true) {
		int lewy1 = wskaznik;
		int prawy2 = wskaznik + (rozmiar-1);
		int prawy1 = wskaznik + (rozmiar-1)/2;
		int lewy2 = prawy1+1;
			
		if(prawy1 > prawy) {
			prawy1 = prawy;
		}
		if(lewy2 > prawy) {
			lewy2 = prawy;
		}
		if(prawy2 > prawy) {
			prawy2 = prawy;
		}
			
		startSortujIPowiekszaj(tab, lewy1, prawy1, lewy2, prawy2);
			
			
		wskaznik = prawy2 + 1;
			
		if(wskaznik>prawy) {	
			wskaznik = lewy;
				
			if(rozmiar>prawy) {
				break;
			}
				
			rozmiar *= 2;
				
		}
	}
}
	
public static void startMergeSort(int tab[], int lewy1, int prawy1, int lewy2, int prawy2) {
	int wLG = lewy1;
	int wPG = lewy2;
	int wskaznik = lewy1;
		
	while(true) {
		if(wLG > prawy1) {
			while(wPG <= prawy2) {
				copy[wskaznik] = tab[wPG];
				wskaznik++;
				wPG++;
			}
			break;
		}
		else if(wPG > prawy2) {
			while(wLG <= prawy1) {
				copy[wskaznik] = tab[wLG];
				wskaznik++;
				wLG++;
			}
			break;
		}
		else if(tab[wLG]<tab[wPG]) {
			copy[wskaznik] = tab[wLG];
			wLG++;
			wskaznik++;
		}
		else if(tab[wLG]>=tab[wPG]) {
			copy[wskaznik] = tab[wPG];
			wPG++;
			wskaznik++;
		}
	}
		
	for(int i=lewy1; i<=prawy2; i++) {
		tab[i] = copy[i];
	}
}

 

1 odpowiedź

0 głosów
odpowiedź 14 maja 2020 przez adrian17 Ekspert (344,860 p.)

Na oko (kod trochę mało czytelny :( ) wygląda jak zwykły merge sort?

https://asciinema.org/a/LtKu152vovBltlgcbdXILRoXB

i pamięci ram

Z definicji ma gorsze zużycie ramu od quicksorta, bo alokuje drugą tablicę o tym samym rozmiarze - a quicksort korzysta tylko ze stosu do głębokości log N.

komentarz 14 maja 2020 przez Pawelixon2001 Nowicjusz (180 p.)
chciałem tylko sprawdzić czy ktoś zwróci uwagę. wiec szybko poprawiłem post że tylko moc obliczeniowy jest optymalizowane.
komentarz 14 maja 2020 przez Pawelixon2001 Nowicjusz (180 p.)
przeniesione 14 maja 2020 przez Arkadiusz Waluk
trochę jest podobny do merge sort tylko że bez rekurencji.

Podobne pytania

0 głosów
0 odpowiedzi 296 wizyt
pytanie zadane 18 października 2020 w C i C++ przez milosz123 Użytkownik (720 p.)
0 głosów
1 odpowiedź 2,400 wizyt
pytanie zadane 2 sierpnia 2017 w C i C++ przez Jakub 0 Pasjonat (23,120 p.)
0 głosów
2 odpowiedzi 97 wizyt
pytanie zadane 8 maja 2023 w C i C++ przez Janchess Początkujący (480 p.)

92,568 zapytań

141,422 odpowiedzi

319,639 komentarzy

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

...