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

VPS Starter Arubacloud
0 głosów
550 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 (349,240 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 387 wizyt
pytanie zadane 18 października 2020 w C i C++ przez milosz123 Użytkownik (720 p.)
0 głosów
1 odpowiedź 2,417 wizyt
pytanie zadane 2 sierpnia 2017 w C i C++ przez Jakub 0 Pasjonat (23,120 p.)
0 głosów
2 odpowiedzi 153 wizyt
pytanie zadane 8 maja 2023 w C i C++ przez Janchess Początkujący (480 p.)

92,980 zapytań

141,943 odpowiedzi

321,189 komentarzy

62,309 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.

Wprowadzenie do ITsec, tom 2

Można już zamawiać tom 2 książki "Wprowadzenie do bezpieczeństwa IT" - będzie to około 650 stron wiedzy o ITsec (17 rozdziałów, 14 autorów, kolorowy druk).

Planowana premiera: 30.09.2024, zaś planowana wysyłka nastąpi w drugim tygodniu października 2024.

Warto preorderować, tym bardziej, iż mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy dodatkowe 15% zniżki! Dziękujemy zaprzyjaźnionej ekipie Sekuraka za kod dla naszej Społeczności!

...