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

西宁圆井模板我自己做的网站网站建设需要大约多少钱

西宁圆井模板我自己做的网站,网站建设需要大约多少钱,wordpress 特色 外链,网站显示危险网站题目描述:在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数。例如,在数组{7,5,6,4}中,一共存在5个逆序对,分别是(7…

题目描述:在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数。例如,在数组{7,5,6,4}中,一共存在5个逆序对,分别是(7,6)、(7,5)、(7,4)、(6,4)、(5,4)。

分析:可以用类似归并排序的思想,将数组二分,直到数组中只有一个元素时,此时数组逆序数组个数为0,然后开始合并数组,分别统计两个合并数组中逆序对的个数,这样自底向上地完成数组的排序及逆序对的统计,实际上是和归并排序是相同的方法。

 

具体地对于计算统计两个子数组的逆序对的个数,我们用两个指针分别指向两个子数组的末尾,并每次比较两个指针指向的数字,如果第一个子数组中的数字大于第二个子数组中的数字,则构成逆序对,并且逆序对的数目等于第二个子数组中剩余数字的个数。如果第一个数组中的数字小于或等于第二个数组中的数字,则不构成逆序对。每次比较,我们都把较大的数字从后往前复制到一个辅助数组,确保辅助数组中的数字是递增排列。

int InversePairs(int* data,int length){if(data == nullptr || length  < 0){return 0;}int* copy = new int[length];for(int i = 0;i < length;++i){      //用一个辅助数组存放排序后的数组元素copy[i] = data[i];              //****归并排序需要将辅助数组元素merge回原数组完成排序*****//}int count = InversePairsCore(data,copy,0,length - 1);//如果要保存排序后的数组可将data和copy参数交换位置:即InversePairCore(copy,data,0,length - 1);delete[] copy;return count;
}int InversePairsCore(int* data,int* copy,int start,int end){if(start == end){            //数组中只有一个元素,返回0//  copy[start] = data[start];     return 0;}int length = (end - start) / 2;int left = InversePairsCore(copy,data,start,start + length);  //copy数组中存放已排序的子数组,接下来会对copy数组作合并和排序操作,//操作的结果放在data数组中,作为下一次合并排序的copy数组(即两个数组,是互相备份的关系),            //***此操作也修改了原输入数组中的元素值***int right = InversePairsCore(copy,data,start + length + 1,end);//i初始化为前半段最后一个元素的一下标int i = start + length;//j初始化为后半段最后一个元素的一下标int j = end;int indexCopy = end;      //辅助数组的下标元素从数组结尾开始int count = 0;while(i >= start && j >= start + length + 1){if(data[i] > data[j]){copy[indexCopy--] = data[i--];count += j - start - length;}else{copy[indexCopy--] = data[j--];}}for(;i >= start;--i){copy[indexCopy--] = data[i];}for(;j >= start + length + 1;--j){copy[indexCopy--] = data[j];}return left + right + count;
}

 

http://www.15wanjia.com/news/173584.html

相关文章:

  • 上海专业做网站公司有哪些域名网查询
  • dart语言做的网站网站开发与建设的原则
  • 流量套餐网站网站建设与经营
  • 西安企业建站费用可信赖的响应式网站
  • php网站开发试卷深圳市住建局官网
  • 做企业展示网站需要多少钱WordPress降低搜索数据库
  • 做外贸在哪个网站找客户旅行社营业部管理办法
  • 服装品牌网站怎么做公司注册网上怎样注册
  • 城乡住房和城乡建设厅网站首页在ppt里面做网站链接
  • 如何做话费卡回收网站家乡介绍网页设计
  • 王璞网站开发实战答案直播教育网站建设
  • 网站开发可以用两种语言吗濮阳市城乡一体化示范区七星医院
  • 赤峰中国建设招标网站游戏网页游
  • 免费自助制作永久网站怎么用linux做网站服务器吗
  • 手机h5网站模板下载dream chaser wordpress
  • 东莞做网站那家好腾讯cdc用wordpress
  • dede装修网站模板公司模块化建设的意义
  • 做一电影网站怎么赚钱吗个人网站的版权怎么写
  • 行唐县网站建设公司frontpage可以做网站吗
  • 快速搭建网站后台成都培训机构哪家好
  • 华为网站建设费用创建网站需要哪些过程
  • 那些公司做网站好企业网站托管价格
  • 网站源码在线提取暴雪战网官网
  • 吉安市建设规划局网站手机视频网站设计
  • 自己建设网站怎么做视频剪辑课程
  • 哈尔滨php网站开发公司养生网站建设
  • 做一个简单的公司网站要多少钱无锡设计师网站
  • 网站优化公司seo案例js模拟点击网站的按钮
  • 滁州建设管理网站ui培训学校哪家好
  • 做网站需要开放哪些端口查权重工具