`
rein07
  • 浏览: 21840 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

快速排序的递归实现

 
阅读更多
快速排序是对冒泡排序的一种改进。它的基本思想是:通过一次排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一不部分的所有数据都要小,然后再按次方法对这两部分数据分别进行快速排序,整个排序过程可以递归或者非递归进行,以此达到整个数据变成有序序列。

下面是快速排序的递归实现:

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 }
分享到:
评论

相关推荐

    快速排序 --- 非递归实现

    快速排序是一种高效的排序算法,由英国计算机科学家C.A.R....总的来说,这个压缩包提供了一个非递归实现快速排序的完整示例,通过自定义栈的数据结构,实现了快速排序算法,适用于理解和学习快速排序的非递归实现方式。

    快速排序的递归简洁实现

    ### 快速排序的递归简洁实现 #### 分区函数(Partition) 分区是快速排序的核心步骤,其主要目标是选择一个基准元素(pivot),并将所有小于等于该基准的元素移动到基准的左边,所有大于该基准的元素移动到基准的...

    快速排序的非递归实现

    通常的快速排序是采用递归实现的,但这里我们讨论的是非递归版本。 非递归实现快速排序的关键在于使用栈来模拟递归调用的过程。在递归版本中,我们首先选择一个基准元素(pivot),然后将数组分为两部分:小于基准...

    JAVA快速排序(递归实现与非递归堆栈模拟实现)

    ### JAVA快速排序(递归实现与非递归堆栈模拟实现) #### 一、递归实现的快速排序 快速排序是一种非常高效的排序算法,它的基本思想是通过一趟排序将待排记录分隔成独立的两部分,其中一部分的所有记录都比另一...

    递归方法实现快速排序

    3. **递归排序**:对基准左边的子数组和右边的子数组分别进行快速排序,这个过程通过递归调用快速排序函数来实现。如果子数组为空,递归结束;否则,重复步骤1和2。 4. **合并结果**:由于排序是就地进行的,不需要...

    java 快速排序 折半查找的界面实现 (递归与分治法)

    总的来说,快速排序和折半查找是计算机科学中不可或缺的算法,通过递归和分治策略,可以在Java中高效地实现这些算法,并结合界面设计,为用户提供直观的交互体验。在实际项目中,理解和掌握这些算法有助于优化数据...

    快速排序递归与非递归的实现

    此文档是快速排序的递归与非递归的具体实现代码

    快速选择非递归与递归算法实现

    快速选择算法是基于快速排序的一种高效选择算法,用于在未排序的数据集合中找到第k小(或第k大)的元素。它由C.A.R. Hoare在1960年提出,是线性时间复杂度的算法,在平均情况下表现优秀。在本主题中,我们将深入探讨...

    基于递归和自定义堆栈的快速排序算法

    快速排序已经是很成熟的排序方法 递归的缺点就是当排序数据量大时,系统堆栈会溢出 递归的实质是在堆栈中不断保存现场,但是现场的数据量是很大的 网上给出了堆栈实现的伪码算法,但是这里面存在很多的BUG 这个程序...

    c语言学习之排序 数据结构 链表 堆排序 希尔排序 快速排序 递归排序

    "C语言学习之排序数据结构链表堆排序希尔排序快速排序递归排序" 本资源主要介绍了C语言中的排序算法,包括链表、堆排序、希尔排序、快速排序和递归排序等五种方法。同时,文章还提供了每种排序方法的原理、流程图和...

    c#快速排序的非递归算法

    它基于分治策略,通常使用递归实现。然而,递归算法可能会导致栈溢出,特别是在处理大规模数据时。为了克服这个问题,我们可以采用非递归的方式来实现快速排序,这种方式不依赖系统栈,而是通过迭代来完成排序过程。...

    插入排序、选择排序、希尔排序、堆排序、冒泡、双向冒泡、快速排序、归并排序、递归的归并排序、基数排序

    9. 递归的归并排序:归并排序通常使用递归实现,通过递归调用自身对数组的前半部分和后半部分进行排序,然后用归并操作合并结果。这种递归方式使算法具有清晰的逻辑结构。 10. 基数排序:基数排序是一种非比较型...

    快速排序算法通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

    2. **递归调用**:C语言支持函数递归,可以用于实现快速排序的递归过程。 3. **内存管理**:虽然快速排序本身并不涉及大量的内存分配和释放,但在大规模数据处理时,递归深度过深可能导致栈溢出,需要考虑适当的优化...

    快速排序的非递归算法.doc

    非递归版本的快速排序则是不使用递归实现这一算法。 在给定的文档中,`quickpass` 函数实现了快速排序的主要逻辑,即“主元交换”(partition)过程。`quicksort` 函数则负责整体的控制,包括栈的管理以及主元交换...

    非递归快速排序

    用栈实现的快速排序,避免了原来的递归算法

    递归函数 递归排序法

    这一过程可以通过递归实现,直到所有元素都排好序。 以下是快速排序的C语言实现示例: ```c void quickSort(int arr[], int left, int right) { if (left ) { int pivot = partition(arr, left, right); ...

    数据结构课件之递归ppt

    课件中提到的快速排序递归实现,就是利用递归在子数组上重复执行排序过程,直到所有元素都在正确位置上。 总的来说,递归是编程中的强大工具,它能简化问题表示,但同时也需要谨慎使用,以避免性能问题。理解和掌握...

    快速排序算法(c#实现)

    在C#中实现快速排序,我们通常会用到递归函数。首先,我们需要一个方法来选取枢轴,这可以是数组的第一个元素、最后一个元素,或者数组中间的元素,也可以是三数取中法,即取首、尾、中间三个元素的中位数作为枢轴,...

    C语言实现多种链表快速排序

    链表是一种重要的数据结构,它在计算机科学...总之,C语言实现链表快速排序是一项挑战性的任务,它涉及到对链表操作和递归算法的深入理解。通过这个实践,可以提升对数据结构和算法的掌握,同时也有助于提高编程技巧。

Global site tag (gtag.js) - Google Analytics