归并排序

很玄学的一道题目,用另类的方法求出逆序对的数量就可以AC

我的思路是这样的:

按照题目,输入数据用两个数组a,b储存,

同时,用另外两个数组c,d分别对应前面两个a,b储存,

就是前面两个的复制

然后在将复制出来的拍一下序,

用另一个类似桶的分别记录在a,b两个数组的数字里面,

某一个数是里面第几大的数

然后按照b里面的顺序,也就是里面的从第一个到最后一个的数在桶里面对应的

是第几个

给a标一下第一第二

比如b中的顺序是 :1 , 3 , 2 , 4

在a中的顺序是 :1 , 4 , 2 , 3

那么根据b的来看,1在b中是第一个所以a中的1对应的还是1

3在b中是第二个,所以a中3对应的是2

.....

这样弄完之后

a成了1 , 4 , 3 , 2

然后归并排序

这里为什么可以用归并排序呢?

归并排序板子是按照大小来排序的,这里却是将a按照b来排序的

所以b就可以看作是大小,是将a在b中的位置看做是大小,这样归并排序按照改

完后的大小排一下

同时记录逆序对,也就是每一个需要挪动的次数

记录和,这个和就是需要挪动的次数的总和

完整代码

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<algorithm>
  4. using namespace std;
  5. const int Max = 100005;
  6. const int mo = 99999997;//注意必须要mo一旦忽视就会错掉两个点
  7. int a[Max],b[Max];
  8. int c[Max],d[Max];
  9. int num1[Max],num2[Max];
  10. int js[Max];
  11. long long ans = 0;
  12. int aa[Max];
  13. void gui(int x,int y)//归并排序板子
  14. {
  15. if(x == y)return;
  16. int mid = (x + y) >> 1;
  17. gui(x,mid);gui(mid + 1,y);
  18. int i = x,j = mid + 1;
  19. int k = x;
  20. while(i <= mid && j <= y)
  21. {
  22. if(a[i] <= a[j])aa[k ++] = a[i ++];
  23. else aa[k ++] = a[j ++],ans += mid - i + 1,ans %= mo;;
  24. }
  25. while(i <= mid)
  26. aa[k ++] = a[i ++];
  27. while(j <= y)
  28. aa[k ++] = a[j ++];
  29. for(int i = x;i <= y;++ i)
  30. a[i] = aa[i];
  31. }
  32. int main()
  33. {
  34. int n;
  35. scanf("%d",&n);
  36. for(int i = 1;i <= n;++ i)scanf("%d",&a[i]),c[i] = a[i];
  37. for(int i = 1;i <= n;++ i)scanf("%d",&b[i]),d[i] = b[i];//输入数据
  38. sort(d + 1,d + 1 + n);
  39. for(int i = 1;i <= n;++ i)
  40. num1[d[i]] = i;
  41. sort(c + 1,c + 1 + n);
  42. for(int i = 1;i <= n;++ i)
  43. num2[c[i]] = i;
  44. for(int i = 1;i <= n;++ i)
  45. js[num1[b[i]]] = i;
  46. for(int i = 1;i <= n;++ i)
  47. a[i] = js[num2[a[i]]];//前面这一大坨都是预处理下标
  48. gui(1,n);
  49. cout << ans % mo <<endl;
  50. return 0;
  51. }

洛谷 P1966 火柴排队 题解的更多相关文章

  1. [NOIP2013提高&洛谷P1966]火柴排队 题解(树状数组求逆序对)

    [NOIP2013提高&洛谷P1966]火柴排队 Description 涵涵有两盒火柴,每盒装有 n 根火柴,每根火柴都有一个高度. 现在将每盒中的火柴各自排成一列, 同一列火柴的高度互不相 ...

  2. 洛谷p1966火柴排队题解

    ps:鉴于你们的蒟蒻yxj实在太蒻辽, 所以, 看不懂也是正常的........ 树状数组 xxy学姐给我们讲的树状数组, 她讲的真的是太好啦!qwq!吹爆xxy 然后, 为了巩固自己, 硬着头皮写题 ...

  3. 【刷题】洛谷 P1966 火柴排队

    题目描述 涵涵有两盒火柴,每盒装有 n 根火柴,每根火柴都有一个高度. 现在将每盒中的火柴各自排成一列, 同一列火柴的高度互不相同, 两列火柴之间的距离定义为: ∑(ai-bi)^2 其中 ai 表示 ...

  4. 洛谷 P1966 火柴排队 解题报告

    P1966 火柴排队 题目描述 涵涵有两盒火柴,每盒装有 \(n\) 根火柴,每根火柴都有一个高度. 现在将每盒中的火柴各自排成一列, 同一列火柴的高度互不相同, 两列火柴之间的距离定义为: \(\s ...

  5. 洛谷——P1966 火柴排队&&P1774 最接近神的人_NOI导刊2010提高(02)

    P1966 火柴排队 这题贪心显然,即将两序列中第k大的数的位置保持一致,证明略: 树状数组求逆序对啦 浅谈树状数组求逆序对及离散化的几种方式及应用 方法:从前向后每次将数插入到bit(树状数组)中, ...

  6. [洛谷P1966] 火柴排队

    题目链接: 火柴排队 题目分析: 感觉比较顺理成章地就能推出来?似乎是个一眼题 交换的话多半会往逆序对上面想,然后题目给那个式子就是拿来吓人的根本没有卵用 唯一的用处大概是告诉你考虑贪心一波,很显然有 ...

  7. 洛谷 P1966 火柴排队

    题目描述 涵涵有两盒火柴,每盒装有 n 根火柴,每根火柴都有一个高度. 现在将每盒中的火柴各自排成一列, 同一列火柴的高度互不相同, 两列火柴之间的距离定义为:∑(ai​−bi​)2 其中ai​ 表示 ...

  8. 洛谷 P1966 火柴排队 —— 思路

    题目:https://www.luogu.org/problemnew/show/P1966 首先,一个排列相邻交换变成另一个排列的交换次数就是逆序对数: 随便画一画,感觉应该是排个序,大的对应大的, ...

  9. 洛谷——P1966 火柴排队

    https://www.luogu.org/problem/show?pid=1966 题目描述 涵涵有两盒火柴,每盒装有 n 根火柴,每根火柴都有一个高度. 现在将每盒中的火柴各自排成一列, 同一列 ...

随机推荐

  1. 为什么重写equals一定要重写hashCode方法?

    大家都知道,equals和hashcode是java.lang.Object类的两个重要的方法,在实际应用中常常需要重写这两个方法,但至于为什么重写这两个方法很多人都搞不明白. 下面我们看下Objec ...

  2. Luogu4548 CTSC2006 歌唱王国 概率生成函数、哈希

    传送门 orz ymd 考虑构造生成函数:设\(F(x) = \sum\limits_{i=0}^\infty f_ix^i\),其中\(f_i\)表示答案为\(i\)的概率:又设\(G(x) = \ ...

  3. 额。。。c++ sort()排序问题

    首先呢 记得 这是个快排 不稳定 基本格式 头文件 #include<algorithm> #include<iostream> bool cmp(int x,int y) { ...

  4. 将ftp目录映射为本地盘符

    1.ftpuser 下载安装FTPUSE下载地址:http://www.ferrobackup.com/ftpuse/ 创建  FTPUSE F: www.xx.com pwd  /USER:admi ...

  5. Python 3 配置文件处理

    首先安装环境 创建配置文件和读取文件 config.ini 内容 [email] mail_server=xxxxx mail_username=xxxx mail_password=xxxxx ma ...

  6. RabbitMQ实战-死信队列

    RabbitMQ死信队列 场景说明 代码实现 简单的Util 生产者 消费者 场景说明 场景: 当队列的消息未正常被消费时,如何解决? 消息被拒绝并且不再重新投递 消息超过有效期 队列超载 方案: 未 ...

  7. Microsoft Visual Studio常用快捷键

    快速补全关键字 1)tab; 删除整行代码 1)Ctrl + L; 回到上一个光标位置/前进到下一个光标位置 1)回到上一个光标位置:使用组合键“Ctrl + -”; 2)前进到下一个光标位置:“Ct ...

  8. mysql 表关系 与 修改表结构

    目录 mysql 表关系 与 修改表结构 两张表关系 分析步骤 修改表结构 mysql 表关系 与 修改表结构 两张表关系 多对一 以员工和部门举例 多个员工对应一个部门 foreign key 永远 ...

  9. JavaPoet的基本使用

    原文:https://blog.csdn.net/crazy1235/article/details/51876192 JavaPoet JavaPoet 是一个用来生成 .java源文件的Java ...

  10. iOS配置TARGETS

    说一下背景 自从这个项目不死不活的迭代了2年,从项目搭建到现在,一直都是自己在开发和维护,所以项目结构非常清晰,但是之前的水平写的代码现在看来也是惨不忍睹,不过本人比较懒,也就没有考虑过重构的事情 - ...