服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - c语言冒泡排序和选择排序的使用代码

c语言冒泡排序和选择排序的使用代码

2022-11-02 12:11路在何方い C/C++

算法中排序是十分重要的,而每一个学习计算机的都会在初期的时候接触到这种排序,下面这篇文章主要给大家介绍了关于c语言冒泡排序和选择排序使用的相关资料,需要的朋友可以参考下

1.冒泡排序

冒泡排序将一个列表中的两个元素进行比较,并将最小的元素交换到顶部。两个元素中较小的会冒到顶部,而较大的会沉到底部,该过程将被重复执行,直到所有元素都被排序。

c语言冒泡排序和选择排序的使用代码

冒泡排序示意图

以如图所示的冒泡排序为例,每次比较相邻的两个值,值小的交换到前面,每轮结束后值最大的数交换到了最后。第一轮需要比较4次;第二轮需要比较3次;第三轮需要比较2次;第四轮需要比较1次。

那么如何用二重循环将5个数排序呢?5个数存放在一维数组中,外层循环控制比较多少轮,循环变量i;内层控制每轮比较多少次,循环变量就,如下图所示:

c语言冒泡排序和选择排序的使用代码

代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#include <stdio.h>
#define NUM 5
void arrsort(int[],int);
void arrout(int[],int);
 main(){
     int a[NUM]={16,25,9,90,23};
     arrout(a,NUM);//输出a数组中原始数据
     arrsort(a,NUM);//对a数组中的数进行排序
     arrout(a,NUM);//输出排序后a数组中的数据
}
void arrsort(int a[],int n){
    for(int i=0;i<n-1;i++){
        for(int j=0;j<n-1-i;j++){
            if(a[j]>a[j+1]){
              int temp =a[j+1];
              a[j+1] = a[j];
              a[j] = temp;
            }
        }
    }
    
}
void arrout(int a[],int n){
   int i;
   for(i=0;i<n;i++){
    printf("%3d",a[i]);
   }
   printf("\n");
 }

输出结果为:

c语言冒泡排序和选择排序的使用代码

2.选择排序

在介绍选择排序法之前,凭介绍一种把最小的数放在第一个位置上的算法,当然也可以用前面所讲的冒泡排序法,现在我们改用一种新的算法: 其指导思想是先并不急于调换位置,先从a[0]开始逐个检查,看哪个数最小,就记下该数所在的位置p,等一躺扫描完毕,再把a[p]和a[0]对调,这时a[0] a[9]最小的数据就换到了最前面的位置。算法的步骤如下。

(1)先假设a[0]的数最小,记下此时的位置p。

(2)依次把a[p]和a[i](从2变化到9)进行比较,每次比较时,若a[j]的数比a[p]中的数小,则把i的值赋给p,使p总是指向当前所扫描过的最小数的位置,也就是说a[p]总是等于所有扫描过的数中最小的那个数。在依次一一比较后,p就指向 10个数中 最小的数所在位置,即a[p]就是10 个数中最小的那个数。

(3)把a[p]和a[0]的数对调,那么最小的数就在a[0]中了,也就是在最前面了。

如果现在重复此算法,但每重复一次, 进行比较的数列范围就向后移动一个位置,即第二遍比较时范围就从第2个数一直到第 n个数,在此范围内找最小的数的位置p,然后把a[p]与a[2]对调,这样从第2个数开始到第n个数中,最小数就在a[2]中了,第三遍就从第个数到第n 个数中去找最小的数,再把a[p]与a[3]对调..此过程重复n-1次后,就把a组中n个数按从小到大的顺序排好了。这种排序的方法就是选择排序法。

下面我们定义一个临时变量temp代替a[p],进行排序。

c语言冒泡排序和选择排序的使用代码

选择排序修改为:从键盘输入的十个整数按升序排列输出

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <stdio.h>
void main(){
  int i,j,k;
  int a[10];
  for(k=0;k<10;k++){
     scanf("%d",&a[k]);
  }
  for(i=0;i<9;i++){
      for(j=i+1;j<10;j++){
         
          if(a[i]>a[j]){
           int temp = a[j];
           a[j] = a[i];
            a[i] = temp;
          }
      }
      
 
  }
  for(i=0;i<10;i++){
    printf("%d ",a[i]);
  }
}

区别

1.冒泡排序是比较相邻位置的两个数,而选择排序是按顺序比较,找最大值或者最小值;

2.冒泡排序每一轮比较后,位置不对都需要换位置,选择排序每一轮比较都只需要换一次位置;

3.冒泡排序是通过数去找位置,选择排序是给定位置去找数;

冒泡排序优缺点

1.优点:比较简单,空间复杂度较低,是稳定的;                 

 2.缺点:时间复杂度太高,效率慢;

选择排序优缺点

1.优点:一轮比较只需要换一次位置;

2.缺点:效率慢,不稳定(举个例子5,8,5,2,9   我们知道第一遍选择第一个元素5会和2交换,那么原序列中2个5的相对位置前后顺序就破坏了)。

总结

到此这篇关于c语言冒泡排序和选择排序使用的文章就介绍到这了,更多相关c语言冒泡排序和选择排序内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/lbqlzch/article/details/84754826

延伸 · 阅读

精彩推荐
  • C/C++C++继承与菱形继承详细介绍

    C++继承与菱形继承详细介绍

    继承(inheritance)机制是面向对象程序设计使代码可以复用的最重要的手段,它允许程序员在保持原有类特性的基础上进行扩展,增加功能,这样产生新的类,...

    小小酥诶10622022-08-26
  • C/C++C语言动态顺序表实例代码

    C语言动态顺序表实例代码

    大家好,本篇文章主要讲的是C语言动态顺序表实例代码,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览...

    bitzhan11122022-07-19
  • C/C++C语言变量类型与输出控制用法实例教程

    C语言变量类型与输出控制用法实例教程

    这篇文章主要介绍了C语言变量类型与输出控制用法,是C语言程序设计中比较基础也是比较重要的用法,需要的朋友可以参考下...

    C语言程序设计10372021-01-29
  • C/C++C++验证LeetCode包围区域的DFS方法

    C++验证LeetCode包围区域的DFS方法

    这篇文章主要介绍了C++验证LeetCode包围区域的DFS方法,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下...

    Grandyang9902021-12-06
  • C/C++C语言实现导航功能

    C语言实现导航功能

    这篇文章主要为大家详细介绍了C语言实现导航功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    徐徐大嫂6882022-10-26
  • C/C++C语言的字符函数和字符串函数详解

    C语言的字符函数和字符串函数详解

    这篇文章主要为大家介绍了C语言的字符函数和字符串函数,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助...

    绅士·永10572022-08-14
  • C/C++C++实现LeetCode(113.二叉树路径之和之二)

    C++实现LeetCode(113.二叉树路径之和之二)

    这篇文章主要介绍了C++实现LeetCode(113.二叉树路径之和之二),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考...

    Grandyang6372021-11-26
  • C/C++C++实现景区信息管理系统

    C++实现景区信息管理系统

    这篇文章主要为大家详细介绍了C++实现景区信息管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    鸿燕藏锋10212021-06-15