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

龙岗外贸网站建设公司东莞seo排名收费

龙岗外贸网站建设公司,东莞seo排名收费,wordpress 微博 插件,东坑网站建设1 直接插入排序 时间复杂度:O(N^2) 空间复杂度:O(1) 稳定性:稳定 元素集合越接近有序,直接插入排序算法的时间效率越高 1.1直接插入排序思想 把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中&#xff…

1 直接插入排序

时间复杂度:O(N^2)
空间复杂度:O(1)
稳定性:稳定

元素集合越接近有序,直接插入排序算法的时间效率越高

1.1直接插入排序思想

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

当插入第i(i>=1)个元素时,前面的array[0],array[1],…,array[i-1]已经排好序,此时用array[i]的排序码与array[i-1],array[i-2],…的排序码顺序进行比较,找到插入位置即将array[i]插入,原来位置上的元素顺序后移
在这里插入图片描述

在这里插入图片描述

1.2直接插入排序代码实现

在这里插入图片描述

void InsertSort(int* a, int n)//直接插入排序:	时间复杂度:O(n*n)	空间复杂度:O(1)
{assert(a);for (int i = 1; i < n; i++)//总共插入n-1次{int temp = a[i];//将最后一个数保存下来int point = i-1;//从倒数第二个数依次往前遍历while (point >= 0)//单趟把末尾的数插入到正确的位置{if (temp < a[point])//把大的数后移(为了保有稳定性,相等的数不后移){a[point + 1] = a[point];point--;}else//因为前面已经排好序了,小于当前的就肯定小于前面的,直接break{break;}}a[point + 1] = temp;//把数插入到对应的位置}
}

2 折半插入排序

时间复杂度:O(N^2)
空间复杂度:O(1)
稳定性:稳定

此算法改变了比较元素的次数,比较的时间复杂度约为O(nlogn),但并未改变元素移动的次数,所以总体来看折半插入排序的时间复杂度仍然是O(n*n)

2.1折半插入排序思想

折半插入排序是直接插入排序的优化,在进行第n个数的插入时,对前面0~n-1个数进行二分查找,找到比第n个数小的数的下标,随后进行后移操作。

2.2折半插入排序代码实现

void InsertSort_Binary(int* a, int n)//折半插入排序:	时间复杂度:O(n*n)	空间复杂度:O(1)
{assert(a);for (int i = 1; i < n; i++)//总共插入n-1次{int temp = a[i];//将最后一个数保存下来int left = 0;int right = i - 1;int mid;while (left<=right)//单次找到小于temp的值的位置{mid = (left + right) / 2;if (temp >= a[mid]){left = mid + 1;}else{right = mid - 1;}}for (int j = i - 1; j >= left; j--)//把此位置及其之后全部后移1位{a[j + 1] = a[j];}a[left] = temp;}
}

3 希尔排序

时间复杂度:O(n^1.3)——O(n*n)
空间复杂度:O(1)
稳定性:不稳定

《数据结构(C语言版)》— 严蔚敏
在这里插入图片描述

《数据结构-用面相对象方法与C++描述》— 殷人昆在这里插入图片描述

3.1希尔排序思想

由前面我们知道,元素集合越接近有序,直接插入排序算法的时间效率越高。所以我们先对数组进行预排序。

先选定一个整数,把待排序文件中所有记录分成个组,所有距离为的记录分在同一组内,并对每一组内的记录进行排序。然后重复上述分组和排序的工作。当到达=1时,所有记录在统一组内排好序。
在这里插入图片描述

3.2希尔排序代码实现

void ShellSort(int* a, int n)//希尔排序:	时间复杂度:O(n^1.3)-O(n^2)	
{int gap = n; while (gap > 1)//gap>1时相当于预排序{gap = gap / 3 + 1;//+1保证了最后一次gap一定是1 for (int i = gap; i < n ; i++)//每一轮走(n-gap)次 {int temp = a[i];//将最后一个数保存下来(每组的最后一个)int point = i - gap;//从倒数第二个数依次往前遍历(每组的倒数第二个)while (point >= 0)//单趟把末尾的数插入到正确的位置{if (temp < a[point]){a[point+gap] = a[point];point -= gap;}else{break;}}a[point+gap] = temp;}}
}
http://www.dtcms.com/wzjs/178468.html

相关文章:

  • 解决方案的网站建设windows优化大师和360哪个好
  • 专门做辅助的网站互联网广告推广是做什么的
  • 做h5免费软件有哪些网络优化工程师工资
  • 亚太建设科技信息研究院网站外贸网站seo推广教程
  • 黑河网站建设搜索引擎优化的基础是什么
  • 在别的公司做的网站可以转走吗广州最新疫情通报
  • 天河公司网站建设做外贸用什么软件找客户
  • 个旧市哪里有做网站网络热词2023
  • dede手机医院网站模板seo排名诊断
  • 临沧网站制作搜狐财经峰会直播
  • 今天出京入京最新通知女生做sem还是seo
  • 网站建设协议 模板域名申请哪家好
  • 做网站需要花钱吗百度站长工具seo查询
  • 佛山新网站制作渠道seo是什么车
  • 如何注册企业成都网站关键词推广优化
  • 深圳哪家网站建设公司好企业网站推广策划书
  • 企业网站建设制作设计哪家最专业如何做网站平台
  • 食品公司网站模板上海百度关键词优化公司
  • 做团购的网站有哪些成人职业技能培训学校
  • 平邑网站建设沧州网站seo公司
  • 黄浦网站建设推广国内广告联盟平台
  • 做企业网站代码那种好市场营销策略
  • mobi域名网站长春网站制作企业
  • 网站建设期任务及总结宁波谷歌优化
  • 内江市住房和城乡建设局网站电话号码网站推广什么意思
  • 怎样做网站策划aso优化运营
  • 做网站的书籍推荐广州seo关键词
  • 自已做好的网站怎么做后台关键词如何排名在首页
  • 华为云做网站不能修改页面近期的新闻热点
  • 官方网站做背景墙厂家链接生成二维码