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

网站建设公司宣传标语口碑营销的形式

网站建设公司宣传标语,口碑营销的形式,web开发是网站开发吗,兰州网站搜索引擎优化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.cadmedia.cn/news/8521.html

相关文章:

  • 手表网站大全好看的html网页
  • 建站申请范文兰州seo培训
  • 海口网站建设平台整站优化全网营销
  • 郑州网站建设宁夏百度推广代理商
  • 西安网站推广哪家稳定百度云搜索引擎入口盘多多
  • 广州建造网站公司公众号排名优化软件
  • 宁波建设委员会网站淘宝seo是指什么
  • 免费的网站app软件郑州网站优化排名
  • 无聊的网站网络营销课程学什么
  • 湖南专业建站按效果付贿苏州网站建设开发公司
  • asp.net 4.0网站开发与项目实战(全程实录) pdf市场调研表模板
  • 如何自己开一个网站网络营销的优势是什么
  • 深圳网站制作电话360网站推广怎么做
  • 杭州新网站建设方案如何免费制作网站
  • wordpress html 插件网站优化种类
  • 网站建设 中企动力南昌百度问答seo
  • 网站会员充值做哪个分录2021十大网络舆情案例
  • 网站建设目标论文电子商务平台建设
  • 2023年文职招聘岗位表网页优化seo公司
  • 音乐网站怎么建设公司推广渠道
  • 网站竞价推广都有哪些自己做一个网站
  • 河南股票配资网站建设做网站建设的公司
  • 浏阳网站建设卷云网络合肥优化排名推广
  • 网站怎么赚钱的搜索引擎优化的含义和目标
  • 兰州网站优化软件搜外
  • 国家知识产权商标注册查询官网seo顾问是什么
  • wordpress 换域名优化网站的步骤
  • 如何添加网站一诺网络推广公司
  • 网站设置专栏全网关键词指数查询
  • 怎么建立网站的流程百度推广售后