博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
算法与数据结构基础(三)插入排序、选择排序和冒泡排序的区别
阅读量:5020 次
发布时间:2019-06-12

本文共 1238 字,大约阅读时间需要 4 分钟。

 插入排序的原理:

始终定义第一个元素为有序的,将元素逐个插入到有序排列之中,其特点是要不断的移动数据,空出一个适当的位置,把待插入的元素放到里面去。插入排序的函数如下:

insertion_sort(int *arr,int len)
{
    int i,j,tmp;
     for(i=1;i<len;i++)
     {
         j=i-1;
        tmp=arr[i];
         while(j>=0&&arr[j]>tmp)
          {
            arr[j+1]=arr[j];
             j--;
        }
        arr[j+1]=tmp;
    }
}
    其中,arr为要排序的数组,len为数组的长度,j为数组下标,tmp为定义的要插入的数。可以看到,在while循环中,不断的去比较待插入的值与有序队列的值,不断的去移动数据,最后找到合适的位置,插入数据。
 

选择排序的原理:

每次在无序队列中“选择”出最小值,放到有序队列的最后,并从无序队列中去除该值(具体实现略有区别)。代码如下:

selection_sort(int *arr, int n)
{
    int i,j,min,temp;
    for(i=0;i<n-1;i++)
    {
        min=i;
        for(j=i+1;j<n;j++)
    {
        if(arr[j]<arr[min])
        {
            min=j;
        }
     }
}
    可以看出,选择排序的特点就是每次选出最小的放到有序队列最后。当然,也可以选出最大值放到有序队列的最前。
 

冒泡排序的原理:

每次在无序队列里将相邻两个数依次进行比较,将小数调换到前面,逐次比较,直至将最大的数移到最后。最将剩下的N-1个数继续比较,将次大数移至倒数第二位。依此规律,直至比较结束。冒泡代码如下:

sort(int *arr,int n)
{
    int i,j,t;
    for(i=0;i<n-1;i++)
    {
        for(j=0;j<n-1-i;j++)
        {
            if(arr[j]>arr[j+1])
            {
                t=arr[j];
                arr[j]=arr[j+1];
                arr[j+1]=t;
            }
        }
    }
}
可以看到当把最大的数移至最后位置时,第二个for循环循环次数减一,即只比较最后位前的N-1位即可。

转载于:https://www.cnblogs.com/chz-blogs/p/9380988.html

你可能感兴趣的文章
ORACLE增删改查以及case when的基本用法
查看>>
[转]oracle10客户端PL/SQL Developer如何连接远程服务器上的oracle数据库
查看>>
HTML5 表单元素和属性
查看>>
SDUTOJ 2498 数据结构实验之图论十一:AOE网上的关键路径
查看>>
使用SpringSocial开发QQ登录
查看>>
好玩的游戏
查看>>
2.6. Statistical Models, Supervised Learning and Function Approximation
查看>>
代码说明call和apply方法的区别 (咱们这方面讲解的少,这样的题有变式,需要举例讲解一下)...
查看>>
T-SQL 类型转换
查看>>
在eclipse中设计BPMN 2.0工作流定义的根本步骤
查看>>
Json对象与Json字符串互转(4种转换方式)
查看>>
PAT甲级1002 链表实现方法
查看>>
查看Linux信息
查看>>
Python中sys模块sys.argv取值并判断
查看>>
【详记MySql问题大全集】四、设置MySql大小写敏感(踩坑血泪史)
查看>>
并查集
查看>>
ubuntu 11.04下android开发环境的搭建!
查看>>
Bzoj 3343: 教主的魔法
查看>>
括号序列(栈)
查看>>
一件趣事
查看>>