vlambda博客
学习文章列表

C语言 | 选择排序

“要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一”

——包租婆

这道理放在C语言学习上也一并受用。在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历的是日积月累的学习。
那么如何学习呢? 当然是每天都练习一道C语言题目!!


作者

闫小林

白天搬砖,晚上做梦。我有故事,你有酒么?


例83:C语言用选择排序对10个数进行排序。


解题思路:选择排序是指第一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,然后再从剩余的未排序元素中寻找到最小(大)元素,然后放到已排序的序列的末尾,,直到全部待排序的数据元素的个数为零。


C语言源代码演示:


#include<stdio.h>//头文件
int main()//主函数
{
  int i,j,temp,array[11];//定义变量
  printf("请输入10个数:\n");//提示语句
  for(i=1;i<=10;i++)
  {
    scanf("%d",&array[i]);
  }
  for(i=1;i<=9;i++)//外层循环
  {
    for(j=i+1;j<=10;j++)//内层循环
    {
      if(array[i]>array[j]) //如果前一个数比后一个数大,则利用中间变量t实现两值互换
      {
        temp=array[i];
        array[i]=array[j];
        array[j]=temp;
      }
    }
  }
  printf("\n排序后顺序:\n");//提示语句
  for(i=1;i<=10;i++)//输出排序后的数
  {
    printf("%5d",array[i]);
  }
  printf("\n");//换行
  return 0;//函数返回值为0
}


编译运行结果:

  
    
    
  
请输入10个数:
10 9 8 2 7 6 1 3 0 11

排序后顺序:
    0    1    2    3    6    7    8    9   10   11

--------------------------------
Process exited after 15.27 seconds with return value 0
请按任意键继续. . .


以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~


    
长按关注

学习C/C++不迷路