300iq Contest 1 C Cool Pairs
为了构造时恰好取到 \(k\) 对时的方便,可以考虑将 \(a\) 设为互不相同的 \(n\) 个数,这样对每个 \(b\) 的取值对答案的贡献就是可以通过调整变成任意值的。
因为要尽可能造成贡献,因此我们先简单地将 \(a\) 设置成 \(-n \sim -1\) 中的每一个数。
那么此时将目光回到 \(b\) 上来,你会发现任意一个 \(b_{q_i}\) 对答案的贡献都可以通过调整取到 \([0, q_i)\) 中的任意一个数。
同时因为 \(b\) 中是有大小关系的,因此可以考虑按照这个大小关系来赋值,这样就可以满足题目的要求了。
那么如果当前的 \(k > q_i - 1\),为了尽可能不给后面留负担,我们要把所有能匹配的数都匹配完;同时为了给后面更大的取值范围,我们将这个数设置为 \(-n\) 即可满足上述两个要求。
那么对于 \(k \le q_i - 1\) 的情况,因为之前的每个数都是取的 \(-n\),因此此时这个位置是能取任意一个数的。
因为 \(a\) 中每个数都是互不相同的,因此通过调整一定能找到一个恰好贡献为 \(k\) 的位置;那么对于后面的所有数,直接填 \(n\) 即可不造成任何贡献。
不难证明这个过程是可以构造出 \(k \in [0, \sum q_i - 1 = \frac{n(n - 1)}{2}]\) 的任意一组解的,复杂度 \(O(n \log n)\)。
#include <bits/stdc++.h>
using namespace std;
#define int long long
#define rep(i, l, r) for (int i = l; i <= r; ++i)
const int N = 300000 + 5;
int n, k, p[N], q[N], a[N], b[N], c[N];
int read() {
char c; int x = 0, f = 1;
c = getchar();
while (c > '9' || c < '0') { if(c == '-') f = -1; c = getchar();}
while (c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
signed main() {
n = read(), k = read();
rep(i, 1, n) p[i] = read();
rep(i, 1, n) q[i] = read();
rep(i, 1, n) a[p[i]] = c[p[i]] = i - n - 1;
rep(i, 1, n) {
if(k > q[i] - 1) b[q[i]] = -n, k -= q[i] - 1;
else if(k == q[i] - 1) {
b[q[i]] = -n;
rep(j, i + 1, n) b[q[j]] = n;
break;
}
else {
sort(c + 1, c + q[i]);
b[q[i]] = -c[k + 1];
rep(j, i + 1, n) b[q[j]] = n;
break;
}
}
puts("Yes");
rep(i, 1, n) printf("%lld ", a[i]); puts("");
rep(i, 1, n) printf("%lld ", b[i]); puts("");
return 0;
}
实际上,我认为像这样固定某一方,从另一方的视角看待整个限制两者的方法也可以认为是一种主元法。
300iq Contest 1 C Cool Pairs的更多相关文章
- 300iq Contest 1 简要题解
300iq Contest 1 简要题解 咕咕咕 codeforces A. Angle Beats description 有一张\(n\times m\)的方阵,每个位置上标有*,+,.中的一种. ...
- 114th LeetCode Weekly Contest Array of Doubled Pairs
Given an array of integers A with even length, return true if and only if it is possible to reorder ...
- [300iq Contest 1-D]Dates
传送门 Description 每个妹子匹配一个时间区间,每个时间最多选择\(a_i\)个妹子,每个妹子有一个快乐值,最大化总快乐值 Solution 贪心,从大往小取,能取则取 判断是否可以有完美匹 ...
- 「题解」300iq Contest 2 H. Honorable Mention
本文将同步发布于: 洛谷博客: csdn: 博客园: 简书. 题目 题目链接:gym102331H. 题意概述 给定一个长度为 \(n\) 的序列 \(a\),有 \(q\) 次询问,每次询问给定三个 ...
- 「题解」300iq Contest 2 B Bitwise Xor
本文将同步发布于: 洛谷博客: csdn: 博客园: 简书. 题目 题目链接:gym102331B. 题意概述 给你一个长度为 \(n\) 的序列 \(a_i\),求一个最长的子序列满足所有子序列中的 ...
- 128th LeetCode Weekly Contest Pairs of Songs With Total Durations Divisible by 60
In a list of songs, the i-th song has a duration of time[i] seconds. Return the number of pairs of s ...
- Pairs Forming LCM(素因子分解)
http://acm.hust.edu.cn/vjudge/contest/view.action?cid=109329#problem/B 全题在文末. 题意:在a,b中(a,b<=n) ...
- POJ2187 Beauty Contest
Description Bessie, Farmer John's prize cow, has just won first place in a bovine beauty contest, ea ...
- 【POJ】2187 Beauty Contest(旋转卡壳)
http://poj.org/problem?id=2187 显然直径在凸包上(黑书上有证明).(然后这题让我发现我之前好几次凸包的排序都错了QAQ只排序了x轴.....没有排序y轴.. 然后本题数据 ...
随机推荐
- golang切片的一些自问自答
你好,我是轩脉刃.这篇是关于go切片的一些问题和回答. go的切片基本上是代码中使用最多的一种数据结构了,使用这种数据结构有哪些要注意的点,这个是非常必要了解的东西.基本上,以前写的一篇博客 http ...
- Nginx 常用配置清单
侦听端口: server {# Standard HTTP Protocollisten 80;# Standard HTTPS Protocollisten 443 ssl;# For http2l ...
- Java EE数据持久化框架作业目录(作业笔记)
第1章 MyBatis入门>>> 1.1.4 在Eclipse中搭建MyBatis基本开发环境 1.2.5 使用MyBatis查询所有职员信息 1.3.3 获取id值为1的角色信息. ...
- Solr单机安装Version5.5.2
Solr安装单机模式,基于Solr的安装版本为5.5.2. 安装规划 IP/机器名 安装软件 运行进程 zdh-9 solr jar 安装用户 solr/zdh1234 hadoop useradd ...
- MD5,SHA1及SHA256等哈希加密方法实现:Java,C#,Golang,Python
哈希算法又称散列算法,它可以从任何数据中快速的创建一个凭证,而这个凭证很难被推倒出来,因为一丁点的变化会导致凭证的差别恨到,也就是说哈希算法具有不可逆性,因此它在密码数据校验方面用的很广,比如我们常用 ...
- Kylin启动步骤
Kylin本身的启动命令比较简单, 但是由于Kylin依赖的其他组件比较多, 所以把完整的启动步骤整理一下. 1.确保集群时间同步 首先查看集群中的时间是否同步 date 如果时间不一致,需要使用如下 ...
- 巅峰对决!Spring Boot VS .NET 6
原文作者:Putu Prema 原文链接: https://medium.com/@putuprema/spring-boot-vs-asp-net-core-a-showdown-1d38b89c6 ...
- ES6常用知识点
一.变量 var:定义的变量有时候会成为全局变量 let:定义的变量严格,只在代码块内有效 const:声明的变量是常量,不能被修改 二.数据类型 字符串 @定义:~字符串定义标记,支持换行. #常 ...
- CAX软件资产管理
CAX软件其实指的是计算机辅助设计软件统称,即CAD.CAM.CAE.CAPP.CAS.CAT.CAI等各项技术的综合叫法,因为这些技术的缩写基本都是以CA为起始,X则表示所有.也就是说,CAX实际上 ...
- 《剑指offer》面试题65. 不用加减乘除做加法
问题描述 写一个函数,求两个整数之和,要求在函数体内不得使用 "+"."-"."*"."/" 四则运算符号. 示例: 输 ...