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

vb.net 做网站全网推广代理

vb.net 做网站,全网推广代理,wordpress采集api插件,接了做网站的单子流程希尔排序为插入排序的优化,即将数组分组,将每一组进行插入排序,每一组排成有序后,最后整体就变有序了。 上面gap2,即5,14,18,27,68为一组;13,20&a…

希尔排序为插入排序的优化,即将数组分组,将每一组进行插入排序,每一组排成有序后,最后整体就变有序了。

 上面gap=2,即5,14,18,27,68为一组;13,20,36,39,51为一组。

gap=2,从a[2]开始,a[2]和a[0]进行插入排序,a[3]和a[1]插入排序,a[4]和a[2]、a[0]插入排序......

为什么 要采取上面分组的方法呢(gap),换一种方法也可以吗?

例如:

相邻元素分为一组
相邻分组排序之后
按gap分组
gap分组排序之后

 可以发现左边都是较小的数据,右边都是较大的数据,更方便把分成的每一个组进行插入排序。

思想:当数据很大的时候,数据的gap设的很大,小的数据会往前放,大的数据会往后放,然后gap逐渐缩小,间隔也会逐渐缩小,整体数据会更加趋于有序,最后用gap=1,此时退化成直接插入排序,这个时候使用直接插入排序效率也会更高。

void Shell(int* arr, int size, int gap)
{for (int i = gap; i < size; i++) {int tmp = arr[i];int j = i - gap;for (; j >= 0; j -= gap) {if (tmp < arr[j]) {arr[j + gap] = arr[j];}else {break;}}arr[j + gap] = tmp;}
}
void ShellSort(int* arr, int size)
{int gap = size;while (gap > 1) {// gap组数变换比较随意,gap /= 3也可以gap /= 2;Shell(arr, size, gap);}// 最后让gap=1再排序一次,即直接插入排序Shell(arr, size, 1);
}

http://www.wangmingla.cn/news/75153.html

相关文章:

  • 网站建设公司全国排行微信怎么做推广
  • 怎么进不了深圳市建设局网站如何创建自己的小程序
  • 代做网站公司哪家好宁德seo推广
  • 商务网站建设试卷长尾词挖掘免费工具
  • 怎样保存网站资料 做证据网站seo优化徐州百度网络
  • 时彩网站开发seo入门
  • 拆分盘网站建设如何自己弄一个网站
  • 论坛网站开发 go搜索引擎技术包括哪些
  • 哈尔滨网站制作招聘网站seo是啥
  • 网站建设的安全威胁营销公司排行
  • 织梦网站支付安装宁波seo外包服务
  • 武汉做网站优化哪家好找相似图片 识别
  • 购物中心网站建设爱站网查询
  • 襄阳市住房和城乡建设局官方网站营销网络是啥意思
  • 网站做外部链接seo关键词排名优化价格
  • 手游平台十大排名襄阳seo培训
  • 自助做网站哪家好成都百度推广电话
  • 中央广播电视总台少儿频道电脑优化工具
  • 如何做微信网站防封优化 英语
  • 企业级网站开发原理图百度手机助手app下载
  • 东莞今日疫情最新消息seo交流网
  • 有哪些网站交互效果做的好的谷歌官方网站注册
  • 如何在网站中做二级下拉菜单seo全称
  • 福田做棋牌网站建设汕头网页搜索排名提升
  • ps如何做音乐网站手机建站系统
  • 建设工程招标网官网搜索引擎优化策略应该包括
  • wordpress页面 中英文重庆seo小z博客
  • 苏州建网站的公司怎么用模板做网站
  • 网站在线留言2021时事政治热点50条
  • 网站建设与设计搜索引擎优化通常要注意的问题有