Diskuze: Implementace QuickSortu - zhodnocení
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 3 zpráv z 3.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
No první věc, která mě napadá, je nepoužívat pole, ale vracet /
přijímat rovnou List. Vyhneš se zbytečnému kopírování.
Dále mi příjde, že v samotné podmínce ti chybí závorky u prvního if
(nejsem si tím jistý, ale nepřiřadí se "else" k prvnímu ifu?). I kdyby to
fungovalo, v rámci lepší čitelnosti, bych ty závorky napsal To samé pro for
Jednu z podmínek si ušetříš tím, že si pivot uložíš externě, a poté
jej odstraníš z pole. Nebudeš muset pokaždé kontrolovat, jestli ne neptáš
na pivot (ušetřená podmínka).
Minimálně bych to přepsal takhle:
public static List<int> QuickSort(List<int> array)
{
if (array.Length <= 1)
return array;
List<int> list = new List<int>();
List<int> left = new List<int>();
List<int> right = new List<int>();
int PivotIndex = array.Length / 2;
int pivot = array[PivotIndex];
array.RemoveAt(PivotIndex);
for (int i = 0; i < array.Length; i++)
{
if (array[i] >= pivot)
right.Add(array[i]);
else
left.Add(array[i]);
}
list.AddRange(QuickSort(left.ToArray()));
list.Add(pivot);
list.AddRange(QuickSort(right.ToArray()));
return list;
}
Potom je tady pár věci, pro které bys musel celý kód přepsat.
Může se stát, že budeš mít data na vstupu tak blbě seřazené, že
QuickSort bude mít složitost n2. Proto se často používá pouze
omezený počet rekurzí, po kterých QuickSort přechází na jiný
algoritmus.
Dále často vytváříš Listy. V každé rekurzi 3 další. Pro
nejefektivnější algoritmus se používá přístup, kdy existuje pouze jedno
pole, se kterým pracuješ. Hodně tím snížíš paměťovou náročnost, ale
nevím, jak moc jsi zkušený, a zda si na to troufneš
Za tu možnost s jedním polem díky. Vidím to na docela výzvu
Zobrazeno 3 zpráv z 3.