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

汕头模板开发建站合肥关键词快速排名

汕头模板开发建站,合肥关键词快速排名,怎么写自己的网页,品牌网站建设怎么收费一、原理 在待排序的数组里&#xff0c;从数组的第二个数字开始&#xff0c;通过构建有序序列&#xff0c;对于未排序数据&#xff0c;在已排序序列中从后向前扫描&#xff0c;找到相应位置并插入。 二、代码部分 #include<stdio.h> #include<stdlib.h> int ma…

一、原理

在待排序的数组里,从数组的第二个数字开始,通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

二、代码部分

#include<stdio.h>
#include<stdlib.h>
 
int main()
{
        int arr[10] = { 9,2,1,3,5,4,10,8,6,7 };
        int flag = 0, i = 0,j = 0;
 
        printf("排列前:");
        for (int i = 0; i < 10; i++)
        {
                printf("%d  ", arr[i]);
        }
        printf("\n\n");
 
        for (i = 1; i < 10; i++)
        {
                flag = arr[i];   //记录arr[i] 的值
                for (j = i - 1; j >= 0 && arr[j] > flag;j--)  //当arr[i]前面的一个数字比a[i]大时
                {
                        arr[j + 1] = arr[j];  //将arr[i] 和其前一个数字进行交换
                }
                arr[j + 1] = flag;
 
        }
 
        printf("排列后:");
        for (int i = 0; i < 10; i++)
        {
                printf("%d  ", arr[i]);
        }
        printf("\n\n");
 
        system("pause");
        return 0;
}

代码输出结果:

 三、代码解析

1、核心代码

        for (i = 1; i < 10; i++)
        {
                flag = arr[i];   //记录arr[i] 的值
                for (j = i - 1; j >= 0 && arr[j] > flag;j--)  //当arr[i]前面的一个数字比arr[i]大时
                {
                        arr[j + 1] = arr[j];  //将arr[i] 和其前一个数字进行交换
                }
                arr[j + 1] = flag;

        }

①因为插入排序的执行轮次为 N-1次,所以这里 i 的循环只有 9 次。

② j 循环的作用,通俗来讲就是每次将大于 a[i] 的数字往后各移一个位置。 

2、 代码的部分运行过程(带图解) 

首先见如下原数组各元素的分布情况:

①i = 1,j = 0,flag = 2,进入 j 的循环后,要执行一次,使 arr[1] = 9,然后再执行  arr[j + 1] = flag,让 arr[0] = 2,最后的结果如下:

②i = 2,j = 1,flag = 1,进入 j 的循环后,要执行两次,第一次使 arr[2] = 9,第二次使 arr[1] = 2,然后再执行  arr[j + 1] = flag,让 arr[0] = 1,最后的结果如下:

③i = 3,j = 2,flag = 3,进入 j 的循环后,要执行一次,使 arr[3] = 9,然后再执行  arr[j + 1] = flag,让 arr[2] = 3,最后的结果如下:

④i = 4,j = 3,flag = 5,进入 j 的循环后,要执行一次,使 arr[4] = 9,然后再执行  arr[j + 1] = flag,让 arr[3] = 5,最后的结果如下:

⑤i = 5,j = 4,flag = 4,进入 j 的循环后,要执行两次,第一次使 arr[5] = 9,第二次使arr[4] = 5,然后再执行  arr[j + 1] = flag,让 arr[3] = 4,最后的结果如下:

⑥i = 6,j = 5,flag = 10,因为不满足 j 的条件,所以直接执行  arr[j + 1] = flag,让 arr[6] = 10(arr[6] 原本就等于10,这步并未对原数组造成影响)。

⑦i = 7,j = 6,flag = 8,进入 j 的循环后,要执行两次,第一次使 arr[7] = 10,第二次使arr[6] = 9,然后再执行  arr[j + 1] = flag,让 arr[5] = 8,最后的结果如下:

⑧i = 8,j = 7,flag = 6,进入 j 的循环后,要执行三次,第一次使 arr[8] = 10,第二次使arr[7] = 9,第三次使arr[6] = 8,然后再执行  arr[j + 1] = flag,让 arr[5] = 6,最后的结果如下:

⑨最后一次,i = 9,j = 8,flag = 7,进入 j 的循环后,要执行三次,第一次使 arr[9] = 10,第二次使arr[8] = 9,第三次使arr[7] = 8,然后再执行  arr[j + 1] = flag,让 arr[6] = 7,最后的结果如下(排列完成):

四、总结 

插入排序的优点:如果是进行相对有序的数组,效率会非常高。不占额外空间,是一种稳定的算法,编写过程也相对简单,时间复杂度高。

插入排序的缺点:遇到数据过多的情况下不是很适用。

http://www.shuangfujiaoyu.com/news/59642.html

相关文章:

  • 郑州网站建设 股权投资关键词一般是指什么
  • 市场营销策略都有哪些汕头网站快速优化排名
  • 介绍北京的网站html网站优化怎么操作
  • 如何查询网站开发windows优化大师好吗
  • 快设计网站官网数据分析师一般一个月多少钱
  • 怎么自己制作游戏手机版长春网站优化页面
  • 温州网站建设制作公司seo关键词优化是什么意思
  • 网站关键词更新东莞关键词排名优化
  • 包头建网站公司哪家强网络营销有哪几种方式
  • 湖南做网站价格正规seo多少钱
  • 自己做的网站 kindle爱站小工具圣经
  • 酒店网络营销推广方案廊坊seo
  • 做php网站的书广州网页推广公司
  • 个人主页网站设计论文seo属于技术还是营销
  • b2c电商网站产品关键词怎么找
  • 温州网站制作计划网球排名即时最新排名
  • 福州企业网站建设网站注册流程和费用
  • 陕西省建设执业资格注册中心网站如何推广小程序
  • 济南营销网站建设公司苏州关键词优化搜索排名
  • 网站推广服务合同seo网络优化是做什么的
  • 免费网站风格品牌推广策略
  • 网站建设 军报湘潭网站设计外包公司
  • 如何百度搜到自己的网站关键词搜索查找工具
  • 京紫元年网站建设汕头seo关键词排名
  • 做照片书的模板下载网站宝鸡seo优化公司
  • 网站网络优化外包想要导航页面推广app
  • 模板网站能用吗百度新闻头条新闻
  • 昆明网站开发多少钱济南网络seo公司
  • html怎么设置网站吗品牌策划公司
  • 做外贸网站企业优网营销