快速排序和归并排序(C语言)
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语言)的更多相关文章
- Java实现单链表的快速排序和归并排序
本文描述了LeetCode 148题 sort-list 的解法. 题目描述如下: Sort a linked list in O(n log n) time using constant space ...
- 排序算法的C语言实现(上 比较类排序:插入排序、快速排序与归并排序)
总述:排序是指将元素集合按规定的顺序排列.通常有两种排序方法:升序排列和降序排列.例如,如整数集{6,8,9,5}进行升序排列,结果为{5,6,8,9},对其进行降序排列结果为{9,8,6,5}.虽然 ...
- 算法分析中最常用的几种排序算法(插入排序、希尔排序、冒泡排序、选择排序、快速排序,归并排序)C 语言版
每次开始动手写算法,都是先把插入排序,冒泡排序写一遍,十次有九次是重复的,所以这次下定决心,将所有常规的排序算法写了一遍,以便日后熟悉. 以下代码总用一个main函数和一个自定义的CommonFunc ...
- Javascript中的冒泡排序,插入排序,选择排序,快速排序,归并排序,堆排序 算法性能分析
阿里面试中有一道题是这样的: 请用JavaScript语言实现 sort 排序函数,要求:sort([5, 100, 6, 3, -12]) // 返回 [-12, 3, 5, 6, 100],如果你 ...
- Java快速排序和归并排序详解
快速排序 概述 快速排序算法借鉴的是二叉树前序遍历的思想,最终对数组进行排序. 优点: 对于数据量比较大的数组排序,由于采用的具有二叉树二分的思想,故排序速度比较快 局限 只适用于顺序存储结构的数据排 ...
- 牛B三人组-快速排序-堆排序-归并排序
快速排序 随便取个数,作为标志值,这里就默认为索引位置为0的值 记录左索引和右索引,从右往左找比标志值小的,小值和左索引值交换,右索引变化,然后从左往右找比标志值大的,大值和右索引值交换,左索引变化 ...
- 数据结构之排序技术:快速排序、归并排序、堆排序(C++版)
快速排序 #include <iostream> using namespace std; void swap(int num[], int i, int j) { int temp = ...
- Scala 实现快速排序和归并排序
def quickSort1(array: Array[Int]): Array[Int] = { def swap(x: Int, y: Int): Unit = { val tmp = array ...
- 牛客网Java刷题知识点之插入排序(直接插入排序和希尔排序)、选择排序(直接选择排序和堆排序)、冒泡排序、快速排序、归并排序和基数排序(博主推荐)
不多说,直接上干货! 插入排序包括直接插入排序.希尔排序. 1.直接插入排序: 如何写成代码: 首先设定插入次数,即循环次数,for(int i=1;i<length;i++),1个数的那次不用 ...
随机推荐
- 「暑期训练」「Brute Force」 Optimal Point on a Line (Educational Codeforces Round 16, B)
题意 You are given n points on a line with their coordinates $x_i$. Find the point x so the sum of dis ...
- 第三十篇 面向对象的三大特性之继承 supre()
继承 一 .什么是继承? 类的继承跟现实生活中的父.子.孙子.重孙子的继承关系一样,父类又称基类. Python中类的继承分为:单继承 和 多继承. # 定义父类 class ParentClass ...
- 论文翻译 - Multiagent Bidirectionally-Coordinated Nets Emergence of Human-level Coordination in Learning to Play StarCraft Combat Games
(缺少一些公式的图或者效果图,评论区有惊喜) (个人学习这篇论文时进行的翻译[谷歌翻译,你懂的],如有侵权等,请告知) Multiagent Bidirectionally-Coordinated N ...
- TensorFlow 同时调用多个预训练好的模型
在某些任务中,我们需要针对不同的情况训练多个不同的神经网络模型,这时候,在测试阶段,我们就需要调用多个预训练好的模型分别来进行预测. 调用单个预训练好的模型请点击此处 弄明白了如何调用单个模型,其实调 ...
- c#执行插入sql 时,报错:异常信息:超时时间已到。在操作完成之前超时时间已过或服务器未响应
问题:c#执行插入sql 时,报错:异常信息:超时时间已到.在操作完成之前超时时间已过或服务器未响应 解决: SqlCommand cmd = new SqlCommand(); cmd.Comman ...
- HDU 4433 locker(DP)(2012 Asia Tianjin Regional Contest)
Problem Description A password locker with N digits, each digit can be rotated to 0-9 circularly.You ...
- C++STL——堆栈
一.相关定义 原理:stack队列是一个线性存储表,插入和删除只在栈顶进行,从而构成了一个后进先出LIFO表. 入栈&出栈:元素的插入称为入栈,元素的删除称为出栈. stack是一种关联容器, ...
- JavaSE复习(六)函数式接口
函数式接口 有且仅有一个抽象方法的接口 @FunctionalInterface注解 一旦使用该注解来定义接口,编译器将会强制检查该接口是否确实有且仅有一个抽象方法,否则将会报错.需要注 意的是,即使 ...
- [译]Python - socket.error: Cannot assign requested address
原文来源: https://stackoverflow.com/questions/48306528/python-socket-error-cannot-assign-requested-addre ...
- [整理]修改git 默认编辑器为vim
git config --global core.editor vim