快速排序算法总结
2021/9/25 20:40:46
本文主要是介绍快速排序算法总结,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
快速排序(Quick Sort)使用分治法策略。
它的基本思想是:选择一个基准数,通过一趟排序将要排序的数据分割成独立的两部分;其中一部分的所有数据都比另外一部分的所有数据都要小。然后,再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
快速排序流程:
(1) 从数列中挑出一个基准值。
(2) 将所有比基准值小的摆放在基准前面,所有比基准值大的摆在基准的后面(相同的数可以到任一边);在这个分区退出之后,该基准就处于数列的中间位置。
(3) 递归地把"基准值前面的子数列"和"基准值后面的子数列"进行排序。
算法核心代码如下:
1 public static void QuickSort(List<int> list) 2 { 3 if(listt.Count < 2) return;//如果数组的元素少于两个直接返回 4 //创建三个数组对象 5 List<int> smaller = new List<int>(); 6 List<int> same = new List<int>(); 7 List<int> larger = new List<int>(); 8 9 int pivot = list[0]; 10 11 foreach(var item in list)//挨个遍历为数组添加元素 12 { 13 if(item < pivot) 14 smaller.Add(item); 15 else if(item > pivot) 16 larger.Add(item); 17 else 18 same.Add(item); 19 } 20 21 QuickSort(smaller);//递归思想 22 QuickSort(larger); 23 24 List.Clear();//清空数组 25 List.AddRange(smaller); 26 List.AddRange(same); 27 List.AddRange(larger) 28 }
这篇关于快速排序算法总结的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-15JavaMailSender是什么,怎么使用?-icode9专业技术文章分享
- 2024-11-15JWT 用户校验学习:从入门到实践
- 2024-11-15Nest学习:新手入门全面指南
- 2024-11-15RestfulAPI学习:新手入门指南
- 2024-11-15Server Component学习:入门教程与实践指南
- 2024-11-15动态路由入门:新手必读指南
- 2024-11-15JWT 用户校验入门:轻松掌握JWT认证基础
- 2024-11-15Nest后端开发入门指南
- 2024-11-15Nest后端开发入门教程
- 2024-11-15RestfulAPI入门:新手快速上手指南