1.0快速排序算法

(1)分解 (2)递归求解 (3)合并

int partition(int a[],int p,int r)

{

    int i=p,j=r+1;

    int x=a[p];

    int temp;

    while(1)  //将<x的元素交换到左边元素,>x的元素交换到右边元素

    {

      while(a[++i]<x && i<r);

      while(a[--j]>x);

      if(i>=j)

        break;

      temp=a[i];

      a[i]=a[j];

      a[j]=temp;

      }

      a[p]=a[j];

      a[j]=x;

      return j;

}

void qSort(int a[],int p,int r,int num)

{

    int i;

    if(p<r)

    {

    int q=partition(a,p,r);

    qSort(a,p,q-1,num);  //对左半段排序

    qSort(a,q+1,r,num); //对右半段排序

    }

    printf("快速排序过程:");

    for(i=0;i<num;i++)

    {

      printf("%d ",a[i]);

    }

      printf("\n");

 }

int main()

{

int num;

int i;

int a[100];

printf("请输入数组长度:");

scanf("%d",&num);

printf("请输入数组:\n");

for(i=0;i<num;i++)

{

scanf("%d",&a[i]);

}

qSort(a,0,num-1,num);

printf("快速排序结果:");

for(i=0;i<num;i++)

{

printf("%d ",a[i]);

}

return 0;

}

2.0归并排序算法

将两个有序的左右子表(以mid区分),合并成一个有序的表

void merge(int a[],int first,int mid,int last)

{

int indexA=first;

int indexB=mid+1;

int tempIndex=0;

int i;

static int temp[1000];

while(indexA<=mid && indexB<=last)//进行左右子表的遍历,如果其中有一个子表遍历完,则跳出循环

{

if(a[indexA]<a[indexB])

{

  temp[tempIndex++]=a[indexA++];

}

else

{

  temp[tempIndex++]=a[indexB++];

}

}

    //有一侧子表遍历完后,跳出循环,将另外一侧子表剩下的数一次放入暂存数组中(有序)

while(indexA<=mid)

{

  temp[tempIndex++]=a[indexA++];

}

while(indexB<=last)

{

  temp[tempIndex++]=a[indexB++];

}

//将暂存数组中有序的数列写入目标数组的制定位置,使进行归并的数组段有序

tempIndex=0;

for(i=first;i<=last;i++)

{

  a[i]=temp[tempIndex++];

}

}

void mergeSort(int a[],int first,int last,int num)

{

int i;

if(first<last)//子表的长度大于1,则进入下面的递归处理

{

  int mid=(first+last)/2;

  mergeSort(a,first,mid,num);

  mergeSort(a,mid+1,first,num);

  merge(a,first,mid,last);

}

printf("合并排序时的数组:\n");

for(i=0;i<num;i++)

{

  printf("%d ",a[i]);

}

printf("\n");

}

int main()

{

int num;

int i;

int a[100];

printf("请输入数组长度:");

scanf("%d",&num);

printf("请输入数组:\n");

for(i=0;i<num;i++)

{

  scanf("%d",&a[i]);

}

mergeSort(a,0,num-1,num);

    printf("合并排序后的数组:\n");

for(i=0;i<num;i++)

{

  printf("%d ",a[i]);

    }

      return 0;

 }

快速排序和归并排序(C语言)的更多相关文章

  1. Java实现单链表的快速排序和归并排序

    本文描述了LeetCode 148题 sort-list 的解法. 题目描述如下: Sort a linked list in O(n log n) time using constant space ...

  2. 排序算法的C语言实现(上 比较类排序:插入排序、快速排序与归并排序)

    总述:排序是指将元素集合按规定的顺序排列.通常有两种排序方法:升序排列和降序排列.例如,如整数集{6,8,9,5}进行升序排列,结果为{5,6,8,9},对其进行降序排列结果为{9,8,6,5}.虽然 ...

  3. 算法分析中最常用的几种排序算法(插入排序、希尔排序、冒泡排序、选择排序、快速排序,归并排序)C 语言版

    每次开始动手写算法,都是先把插入排序,冒泡排序写一遍,十次有九次是重复的,所以这次下定决心,将所有常规的排序算法写了一遍,以便日后熟悉. 以下代码总用一个main函数和一个自定义的CommonFunc ...

  4. Javascript中的冒泡排序,插入排序,选择排序,快速排序,归并排序,堆排序 算法性能分析

    阿里面试中有一道题是这样的: 请用JavaScript语言实现 sort 排序函数,要求:sort([5, 100, 6, 3, -12]) // 返回 [-12, 3, 5, 6, 100],如果你 ...

  5. Java快速排序和归并排序详解

    快速排序 概述 快速排序算法借鉴的是二叉树前序遍历的思想,最终对数组进行排序. 优点: 对于数据量比较大的数组排序,由于采用的具有二叉树二分的思想,故排序速度比较快 局限 只适用于顺序存储结构的数据排 ...

  6. 牛B三人组-快速排序-堆排序-归并排序

    快速排序 随便取个数,作为标志值,这里就默认为索引位置为0的值 记录左索引和右索引,从右往左找比标志值小的,小值和左索引值交换,右索引变化,然后从左往右找比标志值大的,大值和右索引值交换,左索引变化 ...

  7. 数据结构之排序技术:快速排序、归并排序、堆排序(C++版)

    快速排序 #include <iostream> using namespace std; void swap(int num[], int i, int j) { int temp = ...

  8. Scala 实现快速排序和归并排序

    def quickSort1(array: Array[Int]): Array[Int] = { def swap(x: Int, y: Int): Unit = { val tmp = array ...

  9. 牛客网Java刷题知识点之插入排序(直接插入排序和希尔排序)、选择排序(直接选择排序和堆排序)、冒泡排序、快速排序、归并排序和基数排序(博主推荐)

    不多说,直接上干货! 插入排序包括直接插入排序.希尔排序. 1.直接插入排序: 如何写成代码: 首先设定插入次数,即循环次数,for(int i=1;i<length;i++),1个数的那次不用 ...

随机推荐

  1. 【转】Git远程操作详解

    Git是目前最流行的版本管理系统,学会Git几乎成了开发者的必备技能. Git有很多优势,其中之一就是远程操作非常简便.本文详细介绍5个Git命令,它们的概念和用法,理解了这些内容,你就会完全掌握Gi ...

  2. 谷歌面试官经典作品(CTCI)目录

    1.1 判断一个字符串中的字符是否唯一 1.2 字符串翻转 1.3 去除字符串中重复字符 1.8 利用已知函数判断字符串是否为另一字符串的子串 2.1 从链表中移除重复结点 2.2 实现一个算法从一个 ...

  3. 8.Mongodb备份与恢复

    1.备份 语法 mongodump -h dbhost -d dbname -o dbdirectory -h:服务器地址,也可以指定端口号 -d:需要备份的数据库名称 -o:备份的数据存放位置,此目 ...

  4. ubuntu 关闭触控板

    第一种: 1 sudo rmmod psmouse    这个是禁用的 2 sudo modprobe psmouse 这个是启用的 这个方法很便捷,但是会将触点和触板都禁用了,一般还是希望保持触点是 ...

  5. sed 集合(项目中的笔记)

    奇数行和偶数行合并为一行: Like: Sequence number: 5398Sequence name: Glyma.16G123500.1Sequence number: 5399Sequen ...

  6. Qt 贪吃蛇小游戏

    简单的实现了走和变大的样子,剩下的还在完善 贴代码 #include "mainwindow.h" #include "ui_mainwindow.h" #in ...

  7. python 基础篇 06 编码 以及小知识点补充

    本节主要内容: 1. is和==的区别2. 编码的问题 ⼀. is和==的区别1. id()通过id()我们可以查看到⼀个变量表⽰的值在内存中的地址 注  ----<<<在pytho ...

  8. ipfs01

    IPFS音乐播放器 IPFS相关 IPFS第一次亲密接触 什么是IPFS IPFS对比HTTP/FTP等协议的优势 IPFS应用场景 ​ ipfs入门 官网地址:https://ipfs.io 下载安 ...

  9. SQL select 和SQL where语句

    一.SQL SELECT语句 用于从表中选取数据,结果被存储在一共结果表中(称为结果集) 1.语法: SELECT 列名称   FROM  表名称 以及: SELECT * FROM 表名称 注:SQ ...

  10. 【EasyNetQ】- 使用Future Publish调度事件

    许多业务流程要求在将来某个日期安排事件.例如,在与客户进行初次销售联系后,我们可能希望在将来的某个时间安排跟进电话.EasyNetQ可以通过其Future Publish功能帮助您实现此功能.例如,这 ...