洛谷题单指南-分治与倍增-P1966 [NOIP2013 提高组] 火柴排队

news/2025/1/10 12:54:31/文章来源:https://www.cnblogs.com/jcwy/p/18408141

原题链接:https://www.luogu.com.cn/problem/P1966

题意解读:计算两个序列(aibi)^2的最小值,对10^8-3取模。

解题思路:

1、贪心思路

要使得两个序列对应位置元素之差的平方和最小,必须满足两个序列相对排序是一致的,什么意思?

设a序列有两个元素:a1,a2,b序列有两个元素b1,b2

当a1<a2,b1<b2时,(a1-b1)^2 + (a2-b2)^2是最小的!

为什么?

可以分析,如果a1<a2 b1>b2,

令:A = (a1-b1)^2 + (a2-b2)^2,B = (a1-b2)^2 + (a2-b1)^2

将A,B展开,相减

B - A = 2a1b1+2a2b2-2a1b2-2a2b1 = 2a1(b1-b2)-2a2(b1-b2)=2(a1-a2)(b1-b2) < 0

所以B更小,也就是b1,b2交换位置之后,再a1,a2计算距离会更小

所以得出结论:两个序列的相对顺序保持一致是,对应元素之差的平方和最小。

2、逆序对求解

有了以上结论,就可以固定一个序列为标准顺序,然后求将另外一个序列转换成标准顺序需要交换的次数

标准顺序要定义为升序1~n的,另外一个序列转成1~n需要的交换次数就是其逆序对个数。

下面模拟样例:

序列1:1 3 4 2

序列2:1 7 2 4

如果以序列1为基准,先要将序列1的元素进行离散化,这里正好是1~4四个数字,离散化之后也保持不变,我们对每一个元素给定一个序号,已序号的位置为标准顺序

1 3 4 2
序号 1 2 3 4

再对序列2进行离散化处理

原值 1 7 2 4
离散化后值 1 4 2 3
序号 1 2 3 4
离散化后值在序列1中的序号 1 3 4 2

接下来,我们的目标是要将

转换为

只需要计算1 3 4 2的逆序对数,即为2。

100分代码:

#include <bits/stdc++.h>
using namespace std;const int N = 100005, MOD = 1e8 - 3;struct node 
{int value, idx;
};
int n;
long long ans;
node a[N], b[N];
int h[N], c[N];bool cmp_value(node x, node y)
{return x.value < y.value;
}bool cmp_idx(node x, node y)
{return x.idx < y.idx;
}void merge(int s1, int e1, int s2, int e2)
{int i = s1, j = s2;int tmp[e2 - s1 + 1], cnt = 0;while(i <= e1 && j <= e2){if(c[i] <= c[j]) tmp[++cnt] = c[i++];// 如果c[i] > c[j],则c[i]~c[e1]都会比c[j]大,对逆序对的贡献增加了e1 - i + 1个else tmp[++cnt] = c[j++], ans += e1 - i + 1; } while(i <= e1) tmp[++cnt] = c[i++];while(j <= e2) tmp[++cnt] = c[j++];for(int k = 1; k <= cnt; k++) c[k + s1 - 1] = tmp[k];
}void merge_sort(int l, int r)
{if(l >= r) return;int mid = (l + r) / 2;merge_sort(l, mid);merge_sort(mid + 1, r);merge(l, mid, mid + 1, r);
}int main()
{cin >> n;for(int i = 1; i <= n; i++) {cin >> a[i].value;a[i].idx = i;}sort(a + 1, a + n + 1, cmp_value);for(int i = 1; i <= n; i++) a[i].value = i; //把数值按顺序离散化处理for(int i = 1; i <= n; i++) h[a[i].value] = a[i].idx; //保存value-idx的映射关系for(int i = 1; i <= n; i++){cin >> b[i].value;b[i].idx = i;} sort(b + 1, b + n + 1, cmp_value);for(int i = 1; i <= n; i++) b[i].value = i; //把数值按顺序离散化处理sort(b + 1, b + n + 1, cmp_idx); //还原为原来的顺序for(int i = 1; i <= n; i++) c[i] = h[b[i].value]; //c数组是将b的value替换为同样数值在a中对应的idx//计算c中的逆序对merge_sort(1, n);cout << ans % MOD;return 0;
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/795866.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

两款插件让浏览器起飞!

今天给大家分享两款最近在用的实用小插件~1.猫抓 一个用来帮我们嗅探下载网络上各种媒体资源的小插件 当我们浏览的网站有媒体文件时,插件就会自动嗅探视频资源。这时我们只需要点开插件页面,直接下载就好了。不单单是普通的媒体文件,遇见M3U8这种分段式格式,插件还会自动…

养老院视频监控分析系统

养老院视频监控分析系统24h不需要人员监控,对养老院360度及时高清视频监控,即时自动分析和识别养老院监控区域内的异常情况。一旦出现异常,养老院视频监控分析系统马上记录和储存,并把报警信息上传至综合服务平台。除此之外,依据智能视频分析,识别监控区域内的工作人员入…

值班人员睡岗离岗监控报警系统

值班人员睡岗离岗监控报警系统可持续24个小时对值班岗位开展智能化监控。目前,值班人员睡岗离岗监控报警系统识别工作员长时间保持不动的姿态,会被判定为睡岗,随后马上提醒睡岗工作人员。值班人员睡岗离岗监控报警系统同时保存前端分析视频证据并上传至后台,为后续的人工审…

不升级 POI 版本,如何生成符合新版标准的Excel 2007文件

开心一刻 记得小时候,家里丢了钱,是我拿的,可爸妈却一口咬定是弟弟拿的 爸爸把弟弟打的遍体鳞伤,弟弟气愤的斜视着我 我不敢直视弟弟,目光转向爸爸说到:爸爸,你看他,好像还不服问题描述 项目基于 POI 4.1.2 生成 Excel 2007 文件,已经对接了很多客户,也稳定运行了好…

个人简历生成神器!一款在线简历制作工具!

codecv —— 一款制作简历的工具,帮助你以 Markdown 的简洁语法快速编写生成专业的简历,并支持转为 PDF 保存,还提供了海量模板。大家好,我是 Java陈序员。 九月、十月对于广大的程序员来说是找工作的好时节,俗称“金九银十”!无论是社招,还是校招,找工作都需要一份好的…

关于一些字符串操作的常用方法

字符串操作 关于一些字符串操作常用方法 字符串截取string temp = "大家好, 我叫张三。";//索引从0开始截取索引5后面的所有字符串(包括5)Console.WriteLine(temp.Substring(5));//索引从0开始,截取索引5后面4个字符串(包括5)Console.WriteLine(temp.Substring(5, …

前端vue2 常用的函数

1、在el-menu开启路由模式,default-active使用动态值等于当前路由,就需要用:default-active="$route.path" 2、阿里巴巴矢量图icfont的使用①将自己需要的图标下载到矢量库对应的项目文件中 ②更新对应的css代码,点击css代码链接,更新到本地去 ③使用<i class…

证券公司上千台服务器数据同步时,如何进行文件传输管控?

证券公司的数据中心是一个至关重要的基础设施,它承担着数据处理、存储、分析和传输等重要任务,对于保障证券公司的业务连续性、提高运营效率、降低风险等方面具有不可替代的作用。数据中心是企业数据集中的载体和支持平台,是实现数据集中的必要手段。在证券公司中,数据中心…

API接口:功能强大,应用广泛

在当今的数字化世界中,应用程序编程接口(API)无处不在,它们是现代技术架构中不可或缺的组成部分。API接口不仅连接了不同的软件系统,还促进了数据的流动和业务流程的自动化。本文将带您深入了解API接口的功能和广泛应用。一、API接口的定义 API接口是一种允许软件应用程序…

Packaging.DebUOS 专门为 dotnet 应用制作 UOS 安装包

Packaging.DebUOS 是我所在的团队开发开源的一款专门用在为 dotnet 的应用制作成为符合要求的 UOS 统信系统软件安装包的工具,此工具可以辅助开发者使用现有的工具链经过简单的配置即可完成安装包的制作Packaging.DebUOS 是我所在的团队开发开源的一款专门用在为 dotnet 的应用…

python根据关键字查找文件所在路径位置

import os import fnmatchdef find_files(directory, keyword):""" 在给定目录及其子目录中查找包含关键词的文件 """for root, dirs, files in os.walk(directory):for basename in files:if keyword in basename:# 使用 os.path.join 来确保路…

dotnet C# 设置 X11 应用窗口背景透明

本文将告诉大家如何在 X11 里面设置窗口透明不同于在 WPF 里面可以使用 AllowsTransparency 简单方便的设置透明,在 X11 里面设置窗口透明的方法比较绕。需要获取用于传入给到 XCreateWindow 的 Visual 指针,才能实现窗口透明 感谢 walterlv 大佬提供此方法,我只是代为记录的…