首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

C语言选择与冒泡排序

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

2.4K20

C语言 | 选择排序

例83:C语言选择排序对10个数进行排序。...解题思路:选择排序是指第一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,然后再从剩余的未排序元素中寻找到最小(大)元素,然后放到已排序的序列的末尾,,直到全部待排序的数据元素的个数为零...C语言源代码演示: #include//头文件  int main()//主函数  {   int i,j,temp,array[11];//定义变量    printf("请输入10...:\n");//提示语句    for(i=1;i<=10;i++)//输出排序后的数    {     printf("%5d",array[i]);   }    printf("\n");//换行...以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~ C语言学习路线     C语言开发工具 更多案例可以go公众号:C语言入门到精通

1.4K22

C语言冒泡排序

冒泡排序的原理是:从左到右,相邻元素进行比较。通过for循环每次比较一轮,就会找到序列中最大的一个或最小的一个。这个数就会从序列的最右边冒出来。...以从小到大排序为例,第一轮比较后,所有数中最大的那个数就会浮到最右边;第二轮比较后,所有数中第二大的那个数就会浮到倒数第二个位置……就这样一轮一轮地比较,最后实现从小到大排序。...比如对下面这个序列进行从小到大排序: 80  21  156  -90  65 第一轮: 1) 80 和 21比,80>21,则它们互换位置: 21  80  156  -90  65 2) 80 和...至此,整个序列排序完毕。从小到大的序列就是“–90 21 65 80 156”。从这个例子中还可以总结出,如果有 n 个数据,那么只需要比较 n–1 轮。而且除了第一轮之外,每轮都不用全部比较。

2.8K90

C语言 | 选择排序

“要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一” ——包租婆 这道理放在C语言学习上也一并受用。...在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历的是日积月累的学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...例83:C语言选择排序对10个数进行排序。...解题思路:选择排序是指第一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,然后再从剩余的未排序元素中寻找到最小(大)元素,然后放到已排序的序列的末尾,,直到全部待排序的数据元素的个数为零...C语言源代码演示: #include//头文件 int main()//主函数 { int i,j,temp,array[11];//定义变量 printf("请输入10

1.3K52

选择排序

选择排序 分析 假设已经给定了一个无序数组,现在需要将其按照一定顺序排好。现在我们使用选择排序,每次从数组中选出一个最大的元素并将其与数组最后一个元素交换位置,使数组最后一个元素变为最大的。...随着排序的进行,每次需要检查的元素数在逐渐减少,最后一次需要检查的元素都只有一个。既然如此,运行时间怎么还是O(*n*2)呢?这个问题问得好,这与大O表示中的常数相关。...— 《算法图解》 代码实现 C语言实现 因为C中对数组的删除比较麻烦,所以我没有按照《算法图解》中的思路每次选择最小的元素,而是选择了最大的。...arr[biggest_index] = arr[length - 1]; arr[length -1] = temp; length --; } } JAVA语言实现...JAVA实现思路同C

38720

C语言排序算法之选择排序

选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。...首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。...选择排序的主要优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会被移动。...选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。...j; for (i = 0 ; i < len - 1 ; i++) { int min = i; for (j = i + 1; j < len; j++) //走訪未排序的元素

2.3K10

简单选择排序 C语言

简单选择排序 (Simple Selection Sort)也称作直接选择排序。 算法步骤: 1) 设待排序的记录存放在数组Data[1…n]中。...书上的例子: 时间复杂度 O( n 2 n^2 n2) 空间复杂度 O(1) 算法特点: 1 ) 就选择排序方法本身来讲,它是一种稳定的排序 方法,但图中例子所表现出来的现象是不稳定的,这是因为上述实现选择排序的算法采用...“交换记录”的策略所造成的,改变这个策略可以写出不产生“不稳定现象”的选择排序算法。...1;i<=L.length;i++)//利用循环打印顺序表中的数据 printf("%d ",L.Data[i].key); } void SelectSort(SqList &L)//简单选择排序...} } int main() { SqList L; InitList(L);//初始化顺序表 CreateList(L);//创建顺序表 SelectSort(L);//简单选择排序

68030

C语言实现选择排序

选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。...首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。 过程演示: ?...{3, -1, 4, 5, 8, 7, 6, 4, 2, 3};     selection_sort(arr, sizeof(arr) / sizeof(arr[0]));     printf("排序结果...由于每次都是和后面的数字比较,所以最后一位不需要循环     {         int min = i;         for (int j = i + 1; j < length; j++)  {//循环未排序好的数组...                min = j;    //记录最小值             }         }         swap(&arr[min], &arr[i]);    //将最小值交换到最前面,排序

66720
领券