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

网站首页被k 内页还有盐城哪里帮助公司建网址

网站首页被k 内页还有,盐城哪里帮助公司建网址,广州建站模板平台,邮箱域名指的是什么题目: 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数。 题解: ① 我最开始想的蠢方法(会超时,可跳过&#xff…

题目:
在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数。

题解:
① 我最开始想的蠢方法(会超时,可跳过)
首先题目求的逆序对,这考虑的关键应该就是 位置 和 大小

那么我们先将大小排个序,然后从小到大考虑

然后我们按数字从小到大放到由位置排序的容器中
每一次放入,二分搜索当前要放入值的位置,其之后的值的数量,就是该值组成的逆序对数量
这样是不是可以只用考虑位置(因为之前放入容器的值的大小都小于当前值)

这样排序 O(nlogn),然后每次放入值前二分搜索 O(nlogn),但是还是超时了
应该是那个 insert 复杂度太高了,没办法,vector 的 insert 复杂度为 O(n)
想过用其他容器,但好像都不能解决,要是大佬有方法,欢迎评论私信,真想不出来 😟

代码如下:

class Solution {
public:vector<pair<int, int> > temp1;vector<pair<int, int> > temp2;int reversePairs(vector<int>& nums) {int res = 0;for(int i = 0; i < nums.size(); i++) {temp1.push_back(make_pair(nums[i], i));}sort(temp1.begin(), temp1.end());for(int i = 0; i < temp1.size(); i++) {pair<int, int> t = make_pair(temp1[i].second, temp1[i].first);int f = lower_bound(temp2.begin(), temp2.end(), t) - temp2.begin();res = res + i - f;temp2.insert(temp2.begin() + f, t);}return res;}
};

② 分治法(害,我这笨脑子,真的想不到啊)
分治排序都知道吧
我们在排序的过程中,考虑逆序对数量

首先两个有序的序列,求逆序对数量
左边的序列中的某个值所组成逆序对等于右边所有小于它的值的数量

可以通过分治法求解的原理,即
局部的排序,不会影响这部分和其他部分组成逆序对

代码如下:

class Solution {
public:vector<int> numbers;int res = 0;void solve(int l, int r) {int mid = (r + l) / 2;if(r - l > 1) {solve(l, mid);solve(mid, r);}else {return;}vector<int> temp;int flag1 = l, flag2 = mid;while(flag1 < mid) {while(flag2 < r && numbers[flag1] > numbers[flag2]) {temp.push_back(numbers[flag2]);flag2++;}temp.push_back(numbers[flag1]);flag1++;res = res + flag2 - mid;}while(flag2 < r) {temp.push_back(numbers[flag2]);flag2++;}for(int i = l; i < r; i++) {numbers[i] = temp[i - l];}}int reversePairs(vector<int>& nums) {numbers = nums;solve(0, nums.size());return res;}
};
http://www.yayakq.cn/news/657536/

相关文章:

  • 在哪些网站可以做毕业设计上海注册公司代理记账
  • 最有效的网站推广方法企业如何实现高端网站建设
  • 如何进行网站设计规划新河网站快排seo
  • 沈阳电子商务网站建设那些网站可以做h5
  • 网站搭建服务平台国外好的网站
  • 航达建设网站做网站怎么注册营业执照
  • 网站设计中主题有哪些作用房产公司网站建设方案
  • 广东省建设厅网站查询工程公司组织架构
  • 注册网站查询东莞现在属于什么风险地区
  • 外包做网站哪家好百度开户做网站2400
  • html5网站提示网站建设合同英文
  • 用wordpress建立的网站交互网站建设需要做什么
  • 湖北工程公司建设公司网站网站建设性能指标
  • 有没有专做烘焙的网站网站被百度k
  • 商务网站建设试卷招生网站怎么做
  • 设计团队网站中国做网站找谁
  • 找做网站页的在哪找代驾软件开发需要多少钱
  • 看课学校网站建设wordpress虎嗅
  • 大型自适应的网站开发桂林网站开发建设
  • 陕西企业电脑网站制作广撒网网站
  • 创建好网站如何把浏览器上海千樱网站建设
  • 泗洪有做网站wordpress自定义分类筛选
  • 开源php建站系统网站建设英语要几级
  • 天津建站模板搭建前端课程网站
  • 网站安全建设需求网站建站工具
  • 邯郸网站建设推广万先生网站
  • 无锡做网站的企业h5网站开发流程
  • 容桂低价网站建设成都郫县网站建设
  • 电子商务网站建设与运维论文wordpress洋葱
  • asp做的网站设计个体做敦煌网站怎么样