当前位置: 首页 > news >正文

利用国外网站文章图片做书营利百度官网下载

利用国外网站文章图片做书营利,百度官网下载,无锡装修公司做网站,网上简历模板插入排序 基本思想 把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,得到一个新的有序序列 。 打扑克牌整理手牌用的就是插入排序的思想 代码实现 void InsertSort(int* a, int n) { assert(a); …

插入排序

基本思想


把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,得到一个新的有序序列 。

打扑克牌整理手牌用的就是插入排序的思想

代码实现


void InsertSort(int* a, int n)
{
    assert(a);
    for (int i = 0; i < n - 1; i++)//将一个数组中所有元素升序
    {                              //,这里必须是n-1,不然后面数组会越界
        int end=i;
        int x=a[end+1];//x始终指向end下一个位置的值
        while (end >= 0)//每趟插入最多挪动end-1个数据
        {
            if (a[end] > x)//x前一个数大于x,就将数据往后移一格
            {
                a[end + 1] = a[end];//这里数组的值会往后覆盖
                                    //但是没关系,我们已经将a[end+1]的值保存在x当中了
                end--;
            }
            else
            {
                break;//跳出里面的while循环
            }
        }
        a[end + 1] = x;
    }
}

 

特性总结

1. 元素集合越接近有序,直接插入排序算法的时间效率越高
2. 时间复杂度:O(N^2)
3. 空间复杂度:O(1),它是一种稳定的排序算法
4. 稳定性:稳定

选择排序

基本思想

每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完 。

就像小学生排队一样,让最矮的那个站到第一排,然后让第二矮的占到第二排,以此类推

代码实现

void SelectSort(int* a, int n)
{
    int begain = 0;
    int end = n - 1;
    while (begain < end)
    {
        int maxi = begain;//初始化最值
        int mini = begain;
        for (int i = begain; i <= end; i++)
        {
            if (a[i] < a[mini])
            {
                mini = i;//记录下标,否则会有数据被覆盖的问题
            }
            if (a[i] > a[maxi])
            {
                maxi = i;
            }
        }
        swap(&a[begain], &a[mini]);//将最大最小值交换
        swap(&a[end], &a[maxi]);
        begain++;//数组范围往中间缩小
        end--;
    }
}

 

代码优化

上述思想是单向的,我们可以让最高的和最矮的同时排序,就可以优化一下,实现双向排序


void SelectSort(int* a, int n)
{
    int begain = 0;
    int end = n - 1;
    while (begain < end)
    {
        int maxi = begain;
        int mini = begain;
        for (int i = begain; i <=end; i++)
        {
            if (a[i] < a[mini])
            {
                mini = i;//记录下标,否则会有数据被覆盖的问题
            }
            if (a[i] > a[maxi])
            {
                maxi = i;
            }
        }
        swap(&a[begain], &a[mini]);
        if (maxi == begain)//当最大值为begain时,交换最小值和开头元素后,maxi指向的值不再是最大值了.
        {
            maxi = mini;
        }
        swap(&a[end], &a[maxi]);
        begain++;
        end--;
    }
}

 

特性总结

1. 直接选择排序思考非常好理解,但是效率不是很好。实际中很少使用
2. 时间复杂度:O(N^2)
3. 空间复杂度:O(1)
4. 稳定性:不稳定

http://www.khdw.cn/news/45478.html

相关文章:

  • 建一个个人网站要多少钱品牌营销策划方案
  • 郑州手机网站建设百度应用app
  • 织梦rss转wordpressseo技术培训价格表
  • 网站开发中网页之间的链接形式客户营销
  • 石家庄疫情再次爆发关键词优化公司前十排名
  • 大连市卫生健康委员会网站抖音seo系统
  • 做网站优化好的网络公司长沙市seo百度关键词
  • 南充哪里做网站sem优化软件哪家好
  • 做营销网站代理挣钱吗关键词林俊杰mp3在线听
  • 做网站电话销售说辞今天新闻最新消息
  • 云南哪里有给做网站的深圳今日重大新闻
  • 怎么自己做网站排名网络营销专业学什么课程
  • 网站服务运营队伍与渠道建设秦皇岛seo优化
  • 推广网站的方法搜索引擎优化seo专员
  • 手机网站表单验证河北电子商务seo
  • 怎么打帮人 做网站开发的广告百度广告标识
  • 网站开发要多长时间整站优化cms
  • 关于公司网站怎么做精准的搜索引擎优化
  • 小区网站建设广告文案经典范例200字
  • 长沙网站seo收费苏州市网站
  • 网站kv如何做google关键词挖掘工具
  • 郴州嘉禾疫情最新消息谷歌seo是什么意思
  • 我的世界充钱网站怎么做安卓优化大师hd
  • 客服外包公司软件seo中国是什么
  • 做粘土网站推广方式有哪几种
  • 做设计那些网站可以卖设计外链兔
  • 建立子目录网站seo 工具
  • 专业做电子的外贸网站建设百度投放广告平台
  • 大数据公司排名吉安seo网站快速排名
  • 创建免费网站注意事项做网站一般需要多少钱