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

网站 版本 白名单 wap 解析seo排名的影响因素有哪些

网站 版本 白名单 wap 解析,seo排名的影响因素有哪些,如何创建百度网站,南宁外贸网站建设今天给大家简单介绍一下插入排序。 插入排序,其基本思想是将未排序的数据逐步插入到已排序序列中的合适位置,从而使整个序列逐渐有序。 下面我们看一个排序的过程(升序),给定一个int类型的数组,利用插入排…

今天给大家简单介绍一下插入排序。

插入排序,其基本思想是将未排序的数据逐步插入到已排序序列中的合适位置,从而使整个序列逐渐有序。

下面我们看一个排序的过程(升序),给定一个int类型的数组,利用插入排序的方法将这个数组排成升序。思想就是将第一个数据(或者已经有序的几个数据如下图的第2,3,4步)看成是有序的数据,然后利用后一个数据和前一个数据进行对比,若后一个数据比前一个大则不需要改变他们在数组的位置位置,若后一个数据比前一个数据大,那就将他们交换位置,一直循环比较下去直到数组排成升序或者降序。

看下图,我们首先写出假设数组已经有序的情况下的单趟插入排序:

给定一个数组元素为6,end为4,此时若插入为0,比较end位置的数据与0比较,0比end位置的数据小那么0放到end位置,end位置的数据8放到end+1(0的位置)然后end--,依次往前比较直到end<0时结束。若插入为9则不需要挪动数据。

下面为单趟排序代码

int temp = arr[end + 1];// 保存end+1位置的数据以免后面被覆盖了导致数据丢失
while (end >= 0)
{if (temp < arr[end]){arr[end + 1] = arr[end];end--;}else// 不满足则跳出循环{break;}
}
// 不管是循环结束还是break跳出都是往end+1处插入这个数据
arr[end + 1] = temp;

那现在给定一个乱序的数组,我们将第一个数据看成是有序数据,然后让它和他后面一个数据进行比较,那么写一个循环来重复此比较

// 插入排序
void InsertSort(int* arr, int n)
{for (int i = 0;i < n - 1;i++) // 注意结束条件{int end = i;// i=0为第一个数据int temp = arr[end + 1];// 保存end+1位置的数据以免后面被覆盖了导致数据丢失while (end >= 0){if (temp < arr[end]){arr[end + 1] = arr[end];end--;}else{break;}}// 不管是循环结束还是break跳出都是往end+1处插入这个数据arr[end + 1] = temp;}
}

测试排序代码

#define _CRT_SECURE_NO_WARNINGS 
#include <stdio.h>// 插入排序
void InsertSort(int* arr, int n)
{for (int i = 0;i < n - 1;i++) // 注意结束条件{int end = i;// i=0为第一个数据int temp = arr[end + 1];// 保存end+1位置的数据以免后面被覆盖了导致数据丢失while (end >= 0){if (temp < arr[end]){arr[end + 1] = arr[end];end--;}else{break;}}// 不管是循环结束还是break跳出都是往end+1处插入这个数据arr[end + 1] = temp;}
}void Printarry(int* arr, int n)
{for (int i = 0;i < n;i++){printf("%d ", arr[i]);}printf("\n");
}void TestInsertSort() 
{int arr[] = { 3,1,4,2,8,4,9,6,0,7 };Printarry(arr, sizeof(arr) / sizeof(arr[0]));InsertSort(arr, sizeof(arr) / sizeof(arr[0]));Printarry(arr, sizeof(arr) / sizeof(arr[0]));
}int main()
{TestInsertSort();return 0;
}

结论:插入排序是一种简单排序算法,其核心思想是将未排序元素逐个插入到已排序序列的正确位置。算法实现时,首先将第一个元素视为有序序列,然后依次将后续元素(temp)与已排序元素从后往前比较,若temp较小则后移已排序元素,直至找到合适位置插入。文中给出了单趟排序的实现代码和完整插入排序函数,并通过测试用例验证了算法的正确性,成功将无序数组{3,1,4,2,8,4,9,6,0,7}排序为升序序列。

PS:后面补充堆排序和二叉树

http://www.dtcms.com/wzjs/69156.html

相关文章:

  • 深圳网站建设公司jspseo专员是干什么的
  • 福田区龙岗区发布通告刷seo关键词排名软件
  • 动态网站开发基于什么模式优化关键词排名的工具
  • 做网站服务器网站统计代码
  • 大连网站开发师网站推广互联网推广
  • 龙华做网站天无涯网络优化电脑的软件有哪些
  • 镇江企业网站建设最佳磁力吧ciliba磁力链
  • 全国旅游大型网站建设厦门人才网招聘官网
  • 面试学校网站开发安卓优化软件
  • 物联网型网站开发seo快照推广
  • 建站公司都有哪些seo资料网
  • 长沙做网站最好的公司有哪些找精准客户的app
  • 黄埔做网站的公如何做电商
  • 展馆展示设计公司哪家好网站整体优化
  • 网站建设与推cctv-10竞价推广营销
  • c2c网站 多钱建立网站的基本流程
  • 泉州网站建设qzdzi百度信息流怎么收费
  • 青岛专业做外贸网站百度浏览器网站入口
  • 做网站大记事代码南宁今日头条最新消息
  • html5手机网站案例百度推广开户费用标准
  • 网页版qq邮箱怎么发文件一键优化表格
  • 江苏建设部官方网站保定网站制作
  • 网站公司怎么做运营天津短视频seo
  • 做网站 分辨率应该是多少百度公司名称
  • 物流公司在哪做网站站长工具百度百科
  • web开发和网站开发什么区别淘宝seo关键词的获取方法有哪些
  • 苏州工业园区两学一做教育网站搜索引擎是什么意思啊
  • 规划阿里巴巴网站怎么做灰色关键词排名技术
  • jsp网站开发 pdf网络营销师培训
  • 行知智网站开发刚刚刚刚刚刚刚刚刚刚刚刚刚刚刚