• 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)

Cloud VPS
0 głosów
675 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 Mentor (354,700 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 564 wizyt
pytanie zadane 18 października 2020 w C i C++ przez milosz123 Użytkownik (720 p.)
0 głosów
1 odpowiedź 2,469 wizyt
pytanie zadane 2 sierpnia 2017 w C i C++ przez Jakub 0 Pasjonat (23,120 p.)
0 głosów
2 odpowiedzi 334 wizyt
pytanie zadane 8 maja 2023 w C i C++ przez Janchess Początkujący (480 p.)

93,487 zapytań

142,420 odpowiedzi

322,772 komentarzy

62,903 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

Kursy INF.02 i INF.03
...