- 浏览: 21840 次
- 性别:
- 来自: 南京
最新评论
快速排序是对冒泡排序的一种改进。它的基本思想是:通过一次排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一不部分的所有数据都要小,然后再按次方法对这两部分数据分别进行快速排序,整个排序过程可以递归或者非递归进行,以此达到整个数据变成有序序列。
下面是快速排序的递归实现:
view sourceprint?01 #include "stdafx.h"
02
03 #define LIST_INIT_SIZE 100 //顺序表初始大小
04 #define LISTINCREMENT 10 //顺序表增量
05 typedef int ElemType; //顺序表元素类型
06 typedef struct //顺序表结构
07 {
08 ElemType *elem;
09 int length;
10 int listsize;
11 }SqList;
12 //初始化顺序表
13 int InitList_Sq(SqList &L)
14 {
15 L.elem = (ElemType*)malloc(LIST_INIT_SIZE*sizeof(ElemType));
16 if(!L.elem) return -1;
17 L.length = 0;
18 L.listsize = LIST_INIT_SIZE;
19 return 0;
20 }
21 //创建顺序表
22 int CreatList_Sq(SqList &L)
23 {
24 InitList_Sq(L);
25 int i = 1;
26 while(scanf("%d",&L.elem[i]) != EOF)
27 {
28 i++;
29 }
30 L.length = i - 1;
31 return 0;
32 }
33 //一趟快速排序
34 int Partition(SqList &L,int low,int high)
35 {
36 L.elem[0] = L.elem[low];
37 int pivotkey;
38 pivotkey = L.elem[low];
39 int temp;
40 while(low < high)
41 {
42 while(low < high && L.elem[high] >= pivotkey) --high;;
43 L.elem[low] = L.elem[high];
44 while(low < high && L.elem[low] <= pivotkey) ++low;
45 L.elem[high] = L.elem[low];
46 }
47 L.elem[low] = L.elem[0];
48
49 return low;
50 }
51 //递归实现快速排序
52 void QuickSort(SqList &L,int low,int high)
53 {
54 if(low < high)
55 {
56 int pivotloc = Partition(L,low,high);
57 QuickSort(L,low,pivotloc - 1);
58 QuickSort(L,pivotloc + 1,high);
59 }
60 }
61 int _tmain(int argc, _TCHAR *argv[])
62 {
63 SqList L;
64 CreatList_Sq(L);
65 QuickSort(L,1,L.length);
66 for(int i = 1; i <= L.length; i++)
67 {
68 printf("%d ",L.elem[i]);
69 if(LIST_INIT_SIZE == i) printf("\n");
70 }
71 char ch = getchar();
72
73 return 0;
74 }
快速排序的非递归算法:
view sourceprint?01 #include <iostream>
02 #include <stack>
03 using namespace std;
04 template <class T>
05 int partition(T a[],int low,int high)
06 {
07 T v=a[low];
08 while(low<high)
09 {
10 while(low<high && a[high]>=v) high--;
11 a[low]=a[high];
12 while(low<high && a[low]<=v) low++;
13 a[high]=a[low];
14 }
15 a[low]=v;
16 return low;
17
18 }
19
20 template <class T>
21 void QuickSort(T a[],int p,int q)
22 {
23 stack<int> st;
24 int j;
25 do{
26 while(p<q)
27 {
28 j=partition(a,p,q);
29 if( (j-p)<(q-j) )
30 {
31 st.push(j+1);
32 st.push(q);
33 q=j-1;
34 }
35 else
36 {
37 st.push(p);
38 st.push(j-1);
39 p=j+1;
40 }
41 }
42 if(st.empty()) return;
43 q=st.top();st.pop();
44 p=st.top();st.pop();
45 //cout<<endl<<"p:"<<p<<" ";
46 //cout<<"q:"<<q<<endl;
47 }while(1);
48 }
49
50 void main()
51 {
52 //int a[7]={7,6,5,4,3,2,1};
53 //int a[7]={1,2,3,4,5,6,7};
54 int a[7]={3,5,2,3,66,225,1};
55 for(int i=0;i<7;i++)
56 cout<<a[i]<<" ";
57 QuickSort(a,0,6);
58 cout<<endl;
59 for(int i=0;i<7;i++)
60 cout<<a[i]<<" ";
61 }
下面是快速排序的递归实现:
view sourceprint?01 #include "stdafx.h"
02
03 #define LIST_INIT_SIZE 100 //顺序表初始大小
04 #define LISTINCREMENT 10 //顺序表增量
05 typedef int ElemType; //顺序表元素类型
06 typedef struct //顺序表结构
07 {
08 ElemType *elem;
09 int length;
10 int listsize;
11 }SqList;
12 //初始化顺序表
13 int InitList_Sq(SqList &L)
14 {
15 L.elem = (ElemType*)malloc(LIST_INIT_SIZE*sizeof(ElemType));
16 if(!L.elem) return -1;
17 L.length = 0;
18 L.listsize = LIST_INIT_SIZE;
19 return 0;
20 }
21 //创建顺序表
22 int CreatList_Sq(SqList &L)
23 {
24 InitList_Sq(L);
25 int i = 1;
26 while(scanf("%d",&L.elem[i]) != EOF)
27 {
28 i++;
29 }
30 L.length = i - 1;
31 return 0;
32 }
33 //一趟快速排序
34 int Partition(SqList &L,int low,int high)
35 {
36 L.elem[0] = L.elem[low];
37 int pivotkey;
38 pivotkey = L.elem[low];
39 int temp;
40 while(low < high)
41 {
42 while(low < high && L.elem[high] >= pivotkey) --high;;
43 L.elem[low] = L.elem[high];
44 while(low < high && L.elem[low] <= pivotkey) ++low;
45 L.elem[high] = L.elem[low];
46 }
47 L.elem[low] = L.elem[0];
48
49 return low;
50 }
51 //递归实现快速排序
52 void QuickSort(SqList &L,int low,int high)
53 {
54 if(low < high)
55 {
56 int pivotloc = Partition(L,low,high);
57 QuickSort(L,low,pivotloc - 1);
58 QuickSort(L,pivotloc + 1,high);
59 }
60 }
61 int _tmain(int argc, _TCHAR *argv[])
62 {
63 SqList L;
64 CreatList_Sq(L);
65 QuickSort(L,1,L.length);
66 for(int i = 1; i <= L.length; i++)
67 {
68 printf("%d ",L.elem[i]);
69 if(LIST_INIT_SIZE == i) printf("\n");
70 }
71 char ch = getchar();
72
73 return 0;
74 }
快速排序的非递归算法:
view sourceprint?01 #include <iostream>
02 #include <stack>
03 using namespace std;
04 template <class T>
05 int partition(T a[],int low,int high)
06 {
07 T v=a[low];
08 while(low<high)
09 {
10 while(low<high && a[high]>=v) high--;
11 a[low]=a[high];
12 while(low<high && a[low]<=v) low++;
13 a[high]=a[low];
14 }
15 a[low]=v;
16 return low;
17
18 }
19
20 template <class T>
21 void QuickSort(T a[],int p,int q)
22 {
23 stack<int> st;
24 int j;
25 do{
26 while(p<q)
27 {
28 j=partition(a,p,q);
29 if( (j-p)<(q-j) )
30 {
31 st.push(j+1);
32 st.push(q);
33 q=j-1;
34 }
35 else
36 {
37 st.push(p);
38 st.push(j-1);
39 p=j+1;
40 }
41 }
42 if(st.empty()) return;
43 q=st.top();st.pop();
44 p=st.top();st.pop();
45 //cout<<endl<<"p:"<<p<<" ";
46 //cout<<"q:"<<q<<endl;
47 }while(1);
48 }
49
50 void main()
51 {
52 //int a[7]={7,6,5,4,3,2,1};
53 //int a[7]={1,2,3,4,5,6,7};
54 int a[7]={3,5,2,3,66,225,1};
55 for(int i=0;i<7;i++)
56 cout<<a[i]<<" ";
57 QuickSort(a,0,6);
58 cout<<endl;
59 for(int i=0;i<7;i++)
60 cout<<a[i]<<" ";
61 }
发表评论
-
KMP快速字符串查找算法
2011-08-25 19:29 668在C/C++语言编程过程中,一般的字符串搜索操作都是通过标准库 ... -
求解最大公约数问题
2011-08-25 19:27 693最大公因数,又称最大公约数。是指 [n(≧2)个自然数 a1, ... -
堆排序(Heap Sort)算法学习
2011-08-25 19:26 1084在程序设计相关领域, ... -
整数拆分问题的动态规划解法
2011-08-25 19:26 3070输入n,和k,问将n用1到k这k个数字进行拆分,有多少种拆分方 ... -
背包问题介绍与分析
2011-08-25 19:24 1031背包问题是在1978年由Merkel和Hellman提出的。它 ... -
求平方根sqrt()函数的底层算法效率问题
2011-08-25 19:23 1291我们平时经常会有一些数据运算的操作,需要调用sqrt,exp, ... -
面试中常见的一些算法问题
2011-08-25 19:22 697Problem 1 : Is it a loop ? ( ... -
各种排序算法的C++实现与性能比较
2011-08-25 19:21 920排序是计算机算法中非常重要的一项,而排序算法又有不少实现方法, ... -
背包问题之硬币找零问题
2011-08-25 19:19 1173设有6 种不同面值的硬 ... -
求能被1到20的数整除的最小正整数
2011-08-25 19:18 1370求能被1到20的数整除的最小正整数。最直觉的方法是求1到20这 ... -
买书折扣最优惠问题解法
2011-08-25 19:17 752题目:在节假日的时候 ... -
二叉树中的最近公共祖先问题
2011-08-25 19:16 1323题目:要求寻找二叉树中两个节点的最近的公共祖先,并将其返回。 ... -
判断一个整数是否是2的N次方
2011-08-25 19:04 1822题目:给定一个整数num,判断这个整数是否是2的N次方。比如, ... -
字符串逆序的算法汇总
2011-08-25 19:01 1058很早就准备写一个字符串系列的面试题,本来已经写好了,大概有十几 ... -
计算从1到N中1的出现次数
2011-08-25 18:59 598给定一个十进制整数N, ... -
KMP快速字符串查找算法
2011-08-25 18:57 965在C/C++语言编程过程中,一般的字符串搜索操作都是通过标准库 ... -
数字1亿里面有多少个1呢
2011-08-25 18:52 739乍看这题真够唬人的,群里看到这个题目后争先恐后的说看法。最简单 ... -
最大子序列、最长公共子串、最长公共子序列
2011-08-25 18:33 792最大子序列 最大子序列是要找出由数组成的一维数组中和最大的连续 ... -
一道关于男女比例的面试题
2011-08-25 16:56 1038阿里巴巴的一道面试题:说澳大利亚的父母喜欢女孩,如果生出来的第 ...
相关推荐
快速排序是一种高效的排序算法,由英国计算机科学家C.A.R....总的来说,这个压缩包提供了一个非递归实现快速排序的完整示例,通过自定义栈的数据结构,实现了快速排序算法,适用于理解和学习快速排序的非递归实现方式。
### 快速排序的递归简洁实现 #### 分区函数(Partition) 分区是快速排序的核心步骤,其主要目标是选择一个基准元素(pivot),并将所有小于等于该基准的元素移动到基准的左边,所有大于该基准的元素移动到基准的...
通常的快速排序是采用递归实现的,但这里我们讨论的是非递归版本。 非递归实现快速排序的关键在于使用栈来模拟递归调用的过程。在递归版本中,我们首先选择一个基准元素(pivot),然后将数组分为两部分:小于基准...
### JAVA快速排序(递归实现与非递归堆栈模拟实现) #### 一、递归实现的快速排序 快速排序是一种非常高效的排序算法,它的基本思想是通过一趟排序将待排记录分隔成独立的两部分,其中一部分的所有记录都比另一...
3. **递归排序**:对基准左边的子数组和右边的子数组分别进行快速排序,这个过程通过递归调用快速排序函数来实现。如果子数组为空,递归结束;否则,重复步骤1和2。 4. **合并结果**:由于排序是就地进行的,不需要...
总的来说,快速排序和折半查找是计算机科学中不可或缺的算法,通过递归和分治策略,可以在Java中高效地实现这些算法,并结合界面设计,为用户提供直观的交互体验。在实际项目中,理解和掌握这些算法有助于优化数据...
此文档是快速排序的递归与非递归的具体实现代码
快速选择算法是基于快速排序的一种高效选择算法,用于在未排序的数据集合中找到第k小(或第k大)的元素。它由C.A.R. Hoare在1960年提出,是线性时间复杂度的算法,在平均情况下表现优秀。在本主题中,我们将深入探讨...
快速排序已经是很成熟的排序方法 递归的缺点就是当排序数据量大时,系统堆栈会溢出 递归的实质是在堆栈中不断保存现场,但是现场的数据量是很大的 网上给出了堆栈实现的伪码算法,但是这里面存在很多的BUG 这个程序...
"C语言学习之排序数据结构链表堆排序希尔排序快速排序递归排序" 本资源主要介绍了C语言中的排序算法,包括链表、堆排序、希尔排序、快速排序和递归排序等五种方法。同时,文章还提供了每种排序方法的原理、流程图和...
它基于分治策略,通常使用递归实现。然而,递归算法可能会导致栈溢出,特别是在处理大规模数据时。为了克服这个问题,我们可以采用非递归的方式来实现快速排序,这种方式不依赖系统栈,而是通过迭代来完成排序过程。...
9. 递归的归并排序:归并排序通常使用递归实现,通过递归调用自身对数组的前半部分和后半部分进行排序,然后用归并操作合并结果。这种递归方式使算法具有清晰的逻辑结构。 10. 基数排序:基数排序是一种非比较型...
2. **递归调用**:C语言支持函数递归,可以用于实现快速排序的递归过程。 3. **内存管理**:虽然快速排序本身并不涉及大量的内存分配和释放,但在大规模数据处理时,递归深度过深可能导致栈溢出,需要考虑适当的优化...
非递归版本的快速排序则是不使用递归实现这一算法。 在给定的文档中,`quickpass` 函数实现了快速排序的主要逻辑,即“主元交换”(partition)过程。`quicksort` 函数则负责整体的控制,包括栈的管理以及主元交换...
用栈实现的快速排序,避免了原来的递归算法
这一过程可以通过递归实现,直到所有元素都排好序。 以下是快速排序的C语言实现示例: ```c void quickSort(int arr[], int left, int right) { if (left ) { int pivot = partition(arr, left, right); ...
课件中提到的快速排序递归实现,就是利用递归在子数组上重复执行排序过程,直到所有元素都在正确位置上。 总的来说,递归是编程中的强大工具,它能简化问题表示,但同时也需要谨慎使用,以避免性能问题。理解和掌握...
在C#中实现快速排序,我们通常会用到递归函数。首先,我们需要一个方法来选取枢轴,这可以是数组的第一个元素、最后一个元素,或者数组中间的元素,也可以是三数取中法,即取首、尾、中间三个元素的中位数作为枢轴,...
链表是一种重要的数据结构,它在计算机科学...总之,C语言实现链表快速排序是一项挑战性的任务,它涉及到对链表操作和递归算法的深入理解。通过这个实践,可以提升对数据结构和算法的掌握,同时也有助于提高编程技巧。