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

龙华网站建设yihe kj大公司网站建设建网站

龙华网站建设yihe kj,大公司网站建设建网站,openwrt安装wordpress,最新有限公司网站前置知识#xff1a;讲解019-算法笔试中处理输入和输出#xff0c;讲解020-递归和master公式 (1)左部分排好序#xff0c;右部分排好序#xff0c;利用merge过程让左右整体有序(2)merge过程:谁小拷贝谁#xff0c;直到左右两部分所有的数字耗尽(3)递归实现和非递归实现(4…前置知识讲解019-算法笔试中处理输入和输出讲解020-递归和master公式 (1)左部分排好序右部分排好序利用merge过程让左右整体有序(2)merge过程:谁小拷贝谁直到左右两部分所有的数字耗尽(3)递归实现和非递归实现(4)时间复杂度O(n*logn)(5)需要辅助数组所以额外空间复杂度O(n)(6)归并排序为什么比O(n^2)的排序快因为比较行为没有浪费!(7)利用归并排序的便利性可以解决很多问题例如归并分治 注意:有些资料说可以用原地归并排序把额外空间复杂度变成O(1)不要浪费时间去学。因为原地归并排序确实可以省空间但是会把复杂度变成O(n^2) 对这个数组arr[6,4,2,3,9,4] ,进行归并排序  挑其中一步来演示 把[2,4,6]和[3,4,9]合并merge 最后再刷回原数组  void merge(vectorint arr,int left, int mid, int right) {int n right - left 1;vectorint help(n,0);int i 0;int a left;int b mid 1;while (a mid b right) {help[i] arr[a] arr[b] ? arr[a] : arr[b];}// 左侧指针右侧指针必有一个越界另一个不越界while (a mid) {help[i] arr[a];}while (b right) {help[i] arr[b];}for (i 0; i n; i) { // 把 help 里面的数据重新刷回到原数组arrarr[ileft] help[i];} } 1归并排序递归版 // 递归方法 void mergeSort(vectorint arr, int left, int right) {if (left right) return;int mid (left right) / 2;mergeSort(arr, left, mid);mergeSort(arr, mid 1, right);merge(arr, left, mid, right); } 2归并排序非递归版 // 归并排序非递归版 // 时间复杂度O(n * logn) // 空间复杂度O(n) void mergeSort2(vectorint arr) {int n arr.size();// 一共发生O(logn)次for (int left, mid, right, step 1; step n; step 1) {// 内部分组merge时间复杂度O(n)left 0;while (left n) {mid left step - 1;if (mid 1 n) {// 已经没有右侧了break;}// 有右侧,求右侧的右边界right min(left (step 1) - 1, n - 1);// left ... mid mid1 ... right// left ... mid mid1 ... right// left ... mid mid1 ... rightmerge(arr,left, mid, right);left right 1;}} } 完整代码 #include iostream #include vector using namespace std;void merge(vectorint arr,int left, int mid, int right) {int n right - left 1;vectorint help(n,0);int i 0;int a left;int b mid 1;while (a mid b right) {help[i] arr[a] arr[b] ? arr[a] : arr[b];}// 左侧指针右侧指针必有一个越界另一个不越界while (a mid) {help[i] arr[a];}while (b right) {help[i] arr[b];}for (i 0; i n; i) { // 把 help 里面的数据重新刷回到原数组arrarr[ileft] help[i];} }/*归并排序递归版假设left...right一共 n 个数T(n) 2 * T(n/2) O(n)a 2,b 2,c 1根据master公式时间复杂度O(n * logn)空间复杂度O(n) */ // 递归方法 void mergeSort(vectorint arr, int left, int right) {if (left right) return;int mid (left right) / 2;mergeSort(arr, left, mid);mergeSort(arr, mid 1, right);merge(arr, left, mid, right); }// 归并排序非递归版 // 时间复杂度O(n * logn) // 空间复杂度O(n) void mergeSort2(vectorint arr) {int n arr.size();// 一共发生O(logn)次for (int left, mid, right, step 1; step n; step 1) {// 内部分组merge时间复杂度O(n)left 0;while (left n) {mid left step - 1;if (mid 1 n) {// 已经没有右侧了break;}// 有右侧,求右侧的右边界right min(left (step 1) - 1, n - 1);// left ... mid mid1 ... right// left ... mid mid1 ... right// left ... mid mid1 ... rightmerge(arr,left, mid, right);left right 1;}} }int main() {vectorint arr { 6,4,2,3,9,4};int n arr.size();mergeSort(arr, 0, n - 1);//mergeSort2(arr);for (int i 0; i n; i) {cout arr[i] endl;}system(pause);return 0; } 完整图 参考和推荐视频 算法讲解021【必备】归并排序_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1wu411p7r7/?spm_id_from333.999.list.card_archive.clickvd_sourcea934d7fc6f47698a29dac90a922ba5a3
http://www.hkea.cn/news/14278273/

相关文章:

  • 石家庄企业自助建站湖南衡阳市建设工程造价网站
  • 网站模板文件在哪里下载成都seo达人
  • 网站建设的网青岛网上房地产网签查询
  • 郑州网站seo公司在哪个网站上做实验仪器比较好
  • 2019流行做什么网站网站外贸建站是什么意思
  • 宝安网站制作哪家强德州做网站哪家好
  • 改版百度不收录网站网络设计方案ppt
  • 机械建设网站制作上海如何优化网站
  • 做网站用的品牌营销增长新参考价格
  • 青海专业网页设计免费建站提供设计网站效果图
  • 紫搜科技建站教育网站制作费用
  • 海港区网站快排seo原创小说手机网站制作需要多少钱
  • 网站开发core文件作用高端建设网站建设
  • 网站的制作建站人中国建设手机银行app下载
  • 关于建设网站的报告网站后台怎么替换图片
  • 潮州企业网站建设wordpress 增加阅读量
  • 腾讯云建站多少钱中国建设银行官方网站网上银行
  • 襄阳市做网站 优帮云开发公司产品部课件
  • 制作企业网站软件软件开发商是什么意思
  • 菏泽兼职网站建设读书网网站建设策划书
  • 做企业网站制作北京朝阳区最新通知
  • 网站建设公司杭州企业网站建设外包
  • 南昌建网站那家好精准客户怎么营销
  • 使用iframe做网站wordpress使用菜单
  • 口碑好网站建设公司哪家好wordpress 集成paypal
  • 网站正在建设中 免费中企动力邮箱登陆
  • 制作人在那个网站能看广东融都建设有限公司 公司网站
  • 网站建设播放vr视频高校网站群建设
  • 点个赞科技 网站制作网页设计作品及代码
  • 中国建设银行北京分行门户网站公告wordpress 流程图插件