归并排序

很玄学的一道题目,用另类的方法求出逆序对的数量就可以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中的位置看做是大小,这样归并排序按照改

完后的大小排一下

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

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

完整代码

#include<iostream>
#include<cstdio>
#include<algorithm> using namespace std; const int Max = 100005;
const int mo = 99999997;//注意必须要mo一旦忽视就会错掉两个点
int a[Max],b[Max];
int c[Max],d[Max];
int num1[Max],num2[Max];
int js[Max];
long long ans = 0; int aa[Max];
void gui(int x,int y)//归并排序板子
{
if(x == y)return;
int mid = (x + y) >> 1;
gui(x,mid);gui(mid + 1,y);
int i = x,j = mid + 1;
int k = x;
while(i <= mid && j <= y)
{
if(a[i] <= a[j])aa[k ++] = a[i ++];
else aa[k ++] = a[j ++],ans += mid - i + 1,ans %= mo;;
}
while(i <= mid)
aa[k ++] = a[i ++];
while(j <= y)
aa[k ++] = a[j ++];
for(int i = x;i <= y;++ i)
a[i] = aa[i];
} int main()
{
int n;
scanf("%d",&n);
for(int i = 1;i <= n;++ i)scanf("%d",&a[i]),c[i] = a[i];
for(int i = 1;i <= n;++ i)scanf("%d",&b[i]),d[i] = b[i];//输入数据
sort(d + 1,d + 1 + n);
for(int i = 1;i <= n;++ i)
num1[d[i]] = i;
sort(c + 1,c + 1 + n);
for(int i = 1;i <= n;++ i)
num2[c[i]] = i;
for(int i = 1;i <= n;++ i)
js[num1[b[i]]] = i;
for(int i = 1;i <= n;++ i)
a[i] = js[num2[a[i]]];//前面这一大坨都是预处理下标
gui(1,n);
cout << ans % mo <<endl;
return 0;
}

洛谷 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. Ubuntu /etc/security/limits.conf 不生效问题

    一.问题描述 修改 /etc/security/limits.conf ,重启之后不生效 内容如下: * soft nofile * hard nofile root soft nofile root ...

  2. [LOJ6432] [PKUSC2018] 真实排名

    题目链接 LOJ:https://loj.ac/problem/6432 Solution 假设我们当前要算\(x\)的答案,分两种情况讨论: \(x\)没被翻倍,那么\([a_x/2,a_x]\)这 ...

  3. 缓存的设计及PHP实现LFU

    1. 恒定缓存性能有哪些因素? 命中率.缓存更新策略.缓存最大数据量. 命中率:指请求缓存次数和缓存返回正确结果次数的比例.比例越高,缓存的使用率越高,用来衡量缓存机智的好坏和效率.如果数据频繁更新, ...

  4. C# HtmlAgilityPack爬取静态页面

    最近对爬虫很感兴趣,稍微研究了一下,利用HtmlAgilityPack制作了一个十分简单的爬虫,这个简易爬虫只能获取静态页面的Html HtmlAgilityPack简介 HtmlAgilityPac ...

  5. WCF与Web API在应用上的选择

    在最近发布的Visual  Studio 2012及.NET 4.5中, 微软正式推出新的网络服务框架ASP.NET Web API.作为ASP.NET MVC  4的一部分,ASP.NET Web ...

  6. javascript 常见的面试题---数组 && 算法

    网上汇总而来的题目. 第一题: 用 JavaScript 写一个函数,输入 int 型(正整数),返回整数逆序后的字符串.如:输入整型 1234,返回字符串“4321”. 要求必须使用递归函数调用,不 ...

  7. sql强大的行转列功能(内置函数pivot及注意事项)

    语法: PIVOT用于将列值旋转为列名(即行转列),在SQL Server 2000可以用聚合函数配合CASE语句实现 PIVOT的一般语法是:PIVOT(聚合函数(列) FOR 列 in (…) ) ...

  8. 【kafka】一键启动kafka脚本

    3.1 创建文件cd bin 跳转到bin文件夹里touch  start-kafka-cluster.sh --新建一键启动文件touch  stop-kafka-cluster.sh --新建一键 ...

  9. python(函数调用)

    1.在原文件中调用 def abc(x,y): print x + y abc(2,3) #直接通过函数名加括号进行调用传参 2.同一个包(package)下面调用不同文件中的函数 "&qu ...

  10. 【转】关于TCP/IP,必须知道的十个知识点

    本文整理了一些TCP/IP协议簇中需要必知必会的十大问题,既是面试高频问题,又是程序员必备基础素养. 一.TCP/IP模型 TCP/IP协议模型(Transmission Control Protoc ...