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

利用html做博客网站seo排名第一

利用html做博客网站,seo排名第一,网站制作多久能完成,wordpress 装饰插件插入排序 基本思想 把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,得到一个新的有序序列 。 打扑克牌整理手牌用的就是插入排序的思想 代码实现 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.hrbkazy.com/news/21759.html

相关文章:

  • 胖哥网站的建设目标海外seo推广公司
  • 怎么做物流网站代理公司想做个网站怎么办
  • 网站建设咨询有客诚信网站建设咨询广告联盟
  • 合肥网站制作哪儿好薇十大洗脑广告
  • 演示网站怎么做商丘网站推广公司
  • 网站建设属于什么职能汕头seo代理商
  • 医院网站和微信公众号建设方案360搜索优化
  • 用别人公司域名做网站深圳网络推广公司排名
  • 张家港做英文网站邯郸seo优化
  • 东莞网站建设培训学校怎么做神马搜索排名seo
  • 网站测试毕设代做苏州百度快速排名优化
  • 网站建设服务的风险seo长尾关键词优化
  • 金沙网站怎么做代理最新疫情新闻100字
  • 专业的网站建设设计价格怎么做一个免费的网站
  • 南宁网约车司机真实收入seo研究中心vip教程
  • 外链网站 风险青岛运营网络推广业务
  • 自助建站系统注册深圳seo优化排名优化
  • 姓名域名网站打开百度网页
  • 网站建设手机端官网群排名优化软件
  • 关键词诊断优化全部关键词常用的seo网站优化排名
  • 北京网站推广外包自媒体平台排名
  • php和python百度官方优化指南
  • 做一个论坛网站要多少钱苏州做网站的专业公司
  • seo工资水平北京seo关键词优化外包
  • 做婚介网站最新的域名网站
  • 维度网络做网站网络运营课程培训班
  • 在哪个网站上做蓝思测评南昌seo推广公司
  • 网站建设与管理考试题云盘搜索
  • 钦州建设银行社招聘网站百度广告价格
  • 学做网站赚钱方法夫唯老师seo