首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言选择法与冒泡法排序

自学计算机网络的时候看到一张哈佛案例教学精髓的图片,觉得说的不错,顺便想了一下正在学习的C语言,被动学习都做到位了,看课,看书,理解后做笔记等等;主动学习也做了一部分,但只做了实战演练,没有转教别人,结合我...C语言学习过程中遇到的各类麻烦,写篇C语言排序的文章,用我自己的方式讲述,帮助不能理解的朋友理解,顺便得到一些反馈帮助我自己 ?...C语言的排序法有很多种,目前我只学到了选择法和冒泡法,这两种排序主要考察的就是for循环的嵌套循环和数组,里面还涉及一个交换算法,本文的顺序是 交换算法,选择法排序,冒泡法排序 交换算法 交换算法是一个非常常见的算法...选择法排序 选择法排序也是一种很简单的排序,只不过要用for的嵌套循环和条件语句 算法内容: #include int main(void){ int i,j; //定义循环变量...一趟趟的冒泡,排序也就完成了 怎么说呢,冒泡法排序就像打地鼠一样,第一遍把最大的地鼠打到最后,然后第二遍把第二大的地鼠打到最后,依次类推。

2.5K20
您找到你想要的搜索结果了吗?
是的
没有找到

冒泡排序算法,C语言冒泡排序算法详解

冒泡排序是最简单的排序方法,理解起来容易。虽然它的计算步骤比较多,不是最快的,但它是最基本的,初学者一定要掌握。 冒泡排序的原理是:从左到右,相邻元素进行比较。...以从小到大排序为例,第一轮比较后,所有数中最大的那个数就会浮到最右边;第二轮比较后,所有数中第二大的那个数就会浮到倒数第二个位置……就这样一轮一轮地比较,最后实现从小到大排序。...比如对下面这个序列进行从小到大排序: 90 21 132 -58 34 第一轮: 90 和 21比,90>21,则它们互换位置: 21 90 132 -58 34 90 和 132 比,90...因为冒泡排序有一个特点,这个程序是从小到大排序,所以第一轮排序以后,最大的数就会浮到最右面;第二轮排序以后,第二大的数会浮到倒数第二个位置;第三轮排序以后,第三大的数会浮到倒数第三个位置……也就是说,排序多少轮...,就有多少个数字已经按排序要求排好了,它们不需要再比较。

1.9K20

c语言插入排序及希尔排序详解

目录 前言: 插入排序: 希尔排序: 前言: 排序在我们生活中无处不在,比如学生成就排名,商品价格排名等等,所以排序在数据结构的学习中尤为重要,今天就为大家介绍两个经典的排序算法:插入排序和希尔排序...插入排序: 思路图: 思路: 从第二个元素开始和前面的元素依次比较,如果前面的元素比它大,则将该元素移到后一位,如果该元素比它小,则直接插入该元素后面。...,或者说接近逆序   最好情况下为O(N),此时待排序列为升序,或者说接近升序。...空间复杂度:O(1) 希尔排序: 其实希尔排序就是插入排序的进阶版,可以说是希尔对插入排序进行了优化。...思路图: 思路: 步骤一:预排序,使数组接近有序 步骤二:插入排序 先将每间隔gap个元素的数据分为一组,将每组分别进行插入排序,使其接近有序 gap逐渐减小,gap减为1时就是进行步骤二的插入排序

6210

C语言快速排序(非递归)图文详解

前言:   上一期分析了快速排序的三种写法,这三种写法有一个相同点,都是采用递归形式来实现的,那么有没有非递归的方法实现呢?...答案是当然有,用非递归的方法实现快速排序,其实可以借助数据结构中的栈来模拟实现递归的过程。...思路图分析:   因为使用c语言写的,所以需要我们自己写一个栈,栈的实现我这里不再过多赘述,我会把栈的码放在最后。假如我们现在有下面这组数组,我们要对它进行排序。...这里的部分排序,就是选出key,将其放在正确的位置有3种实现方法,如有不懂可以看我上一期博客,这里我选的是双指针法。...然后再将key的左区间和右区间分别入栈,也就是0-3和5-8 3.第二次出栈: 根据栈的性质后入先出,所以我们让5-8出栈: 跟上面一样,每次出栈对相应区间进行一次部分排序排序完如下图: 因为在对这个区间进行部分排序

6710

详解排序算法--堆排序选择排序排序

选择排序 选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。...首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。...选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。 ? !...这就是堆排序的由来 堆排序排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法。...原地堆排序 基于以上堆相关的操作,我们可以很容易的定义堆排序

97130

排序】插入排序与选择排序详解

选择排序是什么? 选择排序是一种简单直观的排序算法。...它的工作原理如下:在未排序序列中找到最小(大)元素,交换到起始位置,该元素为已排序序列的起始元素,继续在剩余未排序元素中找到最小(大)元素,交换到未排序序列起始位置,重复第二步,直到所有元素均排序完毕。...直接选择排序的特性总结: 直接选择排序思考非常好理解,但是效率不是很好。...时间复杂度:O(N^2) 空间复杂度:O(1) 稳定性:不稳定 插入排序 直接插入排序是一种简单的插入排序法,其基本思想是:**把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中...**实际中我们玩扑克牌时,就用了插入排序的思想 如动图: 步骤: 从第一个元素开始,该元素可以认为已经被排序 取出下一个元素,在已经排序的元素序列中从后向前扫描 如果该元素(已排序)大于新元素

9210

快速排序(详解)

描述: 通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列...快速排序 的平均时间复杂度为O(NlogN),是冒泡排序的一种改进版。...方法:快速排序主要采用“二分”的思想,步骤如下: 1)  设置两个变量i、j,排序开始的时候:i=0,j=n-1; 2)第一个数组值作为比较值,首先保存到temp中,即temp=A[0]; 3)然后j-...i],然后j--,避免死循环 5)重复第3、4步,直到i=j,最后将temp值返回s[i]中 6)  然后采用“二分”的思想,以i为分界线,拆分成两个数组 s[0,i-1]、s[i+1,n-1]又开始排序...上 } s[i]=temp; //(5)将比较值放在s[i]上 /*(6)拆分成两个数组 s[0,i-1]、s[i+1,n-1]又开始排序

53490

计数排序详解

一、什么是计数排序? 计数排序(CountSort)是一个非基于比较的排序算法,该算法于1954年由 Harold H. Seward 提出。...它的优势在于在对一定范围内的整数排序时,它的复杂度为Ο(n+k)(其中k是整数的范围),快于任何比较排序算法。...当然这是一种牺牲空间换取时间的做法,而且当O(k)>O(n*log(n))的时候其效率反而不如基于比较的排序(基于比较的排序的时间复杂度在理论上的下限是O(n*log(n)), 如归并排序,堆排序)...实际上,计数排序是将待排序数组的值对应新数组的下标,新数组首先全部初始化为0,只要遇到待排序元素与新数组下标相等便+1,最终在将新数组中的数据按顺序存回原来的数组,这样数组中的元素就有序了。...这样计数排序就完成了。

7710

C语言冒泡排序升序_c语言快速排序和冒泡排序

};//十个数的无序数列 int i,j,t; printf("此程序使用冒泡排序法排列无序数列!...} } printf("排列好的字符组是:\n"); //输出排列好得吃数列 for(i=0;i<10;i++) { printf("%c...{ printf("%c ",a[i]); } return 0; } void function(char a[],int m) { //冒泡排序...:也叫升序排序法,但是相比起二分法查找只能应用于有序数列,二如何将一个无序数列变的有序就可以使用冒泡排序法!!!...对上面的过程进行总结: 该思想体现在成续上的解法是: 实例: 冒泡排序不仅仅可以应用于数字同样可以应用于字符字母的快速排序: 心得体会: 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人

2K10

蓝桥杯C语言知识点补充——快速排序详解

可以说是非常好的算法 快速排序 简介 快速排序(Quicksort)是对冒泡排序的一种改进。 快速排序C. A. R. Hoare在1962年提出。...它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列...原理图 在快速排序算法中,使用了分治策略。首先把序列分成两个子序列,递归地对子序列进行排序,直到整个序列排序结束。...在进行划分之后,轴便在它最终的位置上; 递归地对两个子序列进行重新排序:含有较小元素的子序列和含有较大元素的子序列。 下面的动画展示了快速排序算法的工作原理。 ?...+ 1, right);/*用同样的方式对分出来的右边的小组进行同上的做法*/                       /*当然最后可能会出现很多分左右,直到每一组的i = j 为止*/} 视频详解

98420

C 冒泡排序和选择排序

冒泡排序       理论概念: 从第一个数开始,将相邻的两个数比较,第一个数和第二个数比较,比如说是从小到大的排序,要是后面的数比前面的小则交换两个的位置,这样第一轮比较基数后最大的数就到了最后面,接着进行第二轮的比较...冒泡排序的代码: #include "stdio.h" #define N 10 int main(){ int a[N]; int i,j,t; printf(...选择排序,就像是打擂台一样,我们先选第一个位置的数为基准位置,后面的一个一个挑战,(比如我们从小到大排序),要是第二个数比第一个数小,则更换值(这时候值换了,但擂主的标记位置还是第一个)再比较第三个,要是比第一个又小...后面的还是按照前面的逻辑比较,直到最后一个数,这样就整个排序过程出来了。       第一层循环控制的就是我们设置的擂主的标记,这里只设置一直比较到倒数第二个即可。      ...快速排序的代码: #include "stdio.h" #define N 10 int main( ){ int i,j,t,k; int a[N]; printf("请输入你要排序

51520

C排序算法(一):冒泡排序

冒泡排序 冒泡排序(英语:Bubble Sort)是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们的位置交换过来。走访数列重复地进行直到排序完成。...C语言实现代码 #include #define N 10 int main(void) { int arr[N] = { 0,3,2,5,8,4,7,6,9,1 };//创建一个大小为...0; } 加入用户输入程序 //常见代码会让用户输入他要排序的数据个数,但是有时候用户也不知道自己有几个数 //所以我想实现的是用户之输入一次数据,程序自动计算个数,然后在进行排序的一个过程 //但是调试之后你会发现下面的程序...”**的两个功能,但是我真的搞了一天哇,我太菜了……自闭中…… 算法优化   以对于3 2 0 1 4 5 6 7 8 9从大到小排序,经过一轮排序后会变成2 0 1 3 4 5 6 7 8 9...N,从而达到排序的最大效率,避免不必要的比较。

92820
领券