Atcoder 题面传送门 & 洛谷题面传送门

神仙调整+乱搞题。

首先某些人(including me)一看到最大值最小就二分答案,事实上二分答案对这题正解没有任何启发。

首先将 \(a_i\) 从小到大排序。我们考虑将分配的点对看作一条条线,对于 \(a_x+a_y<M\) 的点对 \((x,y)\) 我们在 \(x,y\) 之间连一条蓝线,对于 \(a_x+a_y\ge M\) 的点对我们在 \(x,y\) 之间连一条红线。

先抛结论,再给证明:如在最优分配方式中,我们的连线方式肯定是长这样的:

证明:使用调整法,证明上述命题,等价于证明对于以下 \(7\) 种情况,左边的情况都可以被调整为右边的情况且答案不会更劣(这里借用了粉兔题解中的图):

我们考虑一一对其进行证明,为了表述方便我们统一假设从左到右四个点分别为 \(a_p,a_q,a_r,a_s\),则显然 \(a_p\le a_q\le a_r\le a_s\):

  1. 对于左边第一个的情况,左边的最大值为 \(\max(a_p+a_q,a_r+a_s)=a_r+a_s\),右边的最大值为 \(\max(a_p+a_s,a_q+a_r)\),而由于 \(a_p+a_s\le a_r+a_s,a_q+a_r\le a_r+a_s\),故右边答案不会比左边更劣。
  2. 对于右边第一个的情况,左边的最大值为 \(\max(a_p+a_r,a_q+a_s-M)\),而由于 \(a_s-M<0\),故 \(a_q+a_s-M<a_q<a_p+a_r\),故左边的最大值实际上是 \(a_p+a_r\),右边的最大值为 \(\max(a_p+a_q,a_r+a_s-M)\),而显然 \(a_p+a_q\le a_p+a_r,a_r+a_s-M<a_r\le a_p+a_r\),故右边答案不会比左边更劣,同时又因为 \(a_p+a_q\le a_p+a_r<M,a_r+a_s\ge a_q+a_s\ge M\),故 \(a_p,a_q\) 之间连的依旧是蓝线,\(a_r,a_s\) 之间连的依旧是红线。
  3. 对于左边第二个的情况,左边的最大值为 \(a_q+a_s\),右边的最大值为 \(\max(a_p+a_s,a_q+a_r)\),而 \(a_p+a_s\le a_q+a_s,a_q+a_r\le a_q+a_s\),故右边答案不会比左边更劣。
  4. 对于右边第二个的情况,左边的最大值为 \(\max(a_p+a_s,a_q+a_r-M)=a_p+a_s\),右边的最大值为 \(\max(a_p+a_q,a_r+a_s-M)\),又由于 \(a_p+a_q\le a_p+a_s,a_r+a_s-M<a_r\le a_p+a_s\),故右边答案不会比左边更劣。
  5. 对于左边第三、四个的情况,证明方法同左边第一、二个,只不过需要整体减个 \(M\)。
  6. 对于右边第三个的情况,左边最大值为 \(\max(a_q+a_r,a_p+a_s-M)=a_q+a_r\),右边最大值为 \(\max(a_p+a_q,a_r+a_s-M)\),又由于 \(a_p+a_q\le a_q+a_r,a_r+a_s-M<a_r\le a_q+a_r\),故右边答案不会比左边更劣。

综上,只要出现线相交或者不同颜色的线出现包含关系的情况,都可以被调整,证毕。

接下来考虑怎样求答案,暴力枚举分割点显然是不可行的,不过注意到对于两个不同且均合法的分割点 \(p\) 和 \(p'\),如果 \(p<p'\),那么以 \(p\) 为分割点的每条线的权值都小于以 \(p'\) 为分割点的每条线的权值,因此我们肯定希望分割点越靠左越好,而如果我们分割点太左了(yyq:政治学得很好嘛),那就会出现右侧有的线不是红线的情况,因此我们可以二分找出合法的且最靠左的分割点 \(p\),然后求出答案即可。

时间复杂度线性对数。

namespace fastio{
#define FILE_SIZE 1<<23
char rbuf[FILE_SIZE],*p1=rbuf,*p2=rbuf,wbuf[FILE_SIZE],*p3=wbuf;
inline char getc(){return p1==p2&&(p2=(p1=rbuf)+fread(rbuf,1,FILE_SIZE,stdin),p1==p2)?-1:*p1++;}
inline void putc(char x){(*p3++=x);}
template<typename T> void read(T &x){
x=0;char c=getchar();T neg=0;
while(!isdigit(c)) neg|=!(c^'-'),c=getchar();
while(isdigit(c)) x=(x<<3)+(x<<1)+(c^48),c=getchar();
if(neg) x=(~x)+1;
}
template<typename T> void recursive_print(T x){if(!x) return;recursive_print(x/10);putc(x%10^48);}
template<typename T> void print(T x){if(!x) putc('0');if(x<0) putc('-'),x=~x+1;recursive_print(x);}
template<typename T> void print(T x,char c){if(!x) putc('0');if(x<0) putc('-'),x=~x+1;recursive_print(x);putc(c);}
void print_final(){fwrite(wbuf,1,p3-wbuf,stdout);}
}
using namespace fastio;
const int MAXN=1e5;
int n,m,a[MAXN*2+5];
int add(int x,int y){return (x+y<m)?(x+y):(x+y-m);}
bool check(int mid){bool flg=1;for(int i=(mid<<1)+1;i<=n<<1;i++) flg&=(a[i]+a[(n<<1)+(mid<<1)+1-i]>=m);return flg;}
int main(){
read(n);read(m);
for(int i=1;i<=n<<1;i++) read(a[i]);
sort(a+1,a+(n<<1)+1);int l=0,r=n,p=-1;
while(l<=r){
int mid=l+r>>1;
if(check(mid)) p=mid,r=mid-1;
else l=mid+1;
} int mx=0;
// printf("%d\n",p);
for(int i=1;i<=p<<1;i++) chkmax(mx,add(a[i],a[(p<<1)+1-i]));
for(int i=(p<<1)+1;i<=n<<1;i++) chkmax(mx,add(a[i],a[(n<<1)+(p<<1)+1-i]));
printf("%d\n",mx);
return 0;
}

Atcoder Grand Contest 032 E - Modulo Pairing(乱搞+二分)的更多相关文章

  1. Atcoder Grand Contest 032

    打的第一场Atcoder,已经知道会被虐得很惨,但没有想到竟然只做出一题-- 思维急需提升. A - Limited Insertion 这题还是很签到的. 感觉正着做不好做,我们反着来,把加数变为删 ...

  2. AtCoder Grand Contest 032 A - Limited Insertion( 思维)

    Time Limit: 2 sec / Memory Limit: 1024 MB Score : 400400 points Problem Statement Snuke has an empty ...

  3. AtCoder Grand Contest 032 B - Balanced Neighbors——构造

    题意 B - Balanced Neighbors 给定一个整数 $N$($3\leq N \leq 100$),构造一个顶点编号为 $1...N$ 的无向图,需满足如下两个条件: 简单图且连通 存在 ...

  4. Atcoder Grand Contest 006 D - Median Pyramid Hard(二分+思维)

    Atcoder 题面传送门 & 洛谷题面传送门 u1s1 Atcoder 不少思维题是真的想不出来,尽管在 Atcoder 上难度并不高 二分答案(这我倒是想到了),检验最上面一层的数是否 \ ...

  5. 【AtCoder Grand Contest 007E】Shik and Travel [Dfs][二分答案]

    Shik and Travel Time Limit: 50 Sec  Memory Limit: 512 MB Description 给定一棵n个点的树,保证一个点出度为2/0. 遍历一遍,要求每 ...

  6. AtCoder Grand Contest 010

    AtCoder Grand Contest 010 A - Addition 翻译 黑板上写了\(n\)个正整数,每次会擦去两个奇偶性相同的数,然后把他们的和写会到黑板上,问最终能否只剩下一个数. 题 ...

  7. AtCoder Grand Contest 012

    AtCoder Grand Contest 012 A - AtCoder Group Contest 翻译 有\(3n\)个人,每一个人有一个强大值(看我的假翻译),每三个人可以分成一组,一组的强大 ...

  8. AtCoder Grand Contest 011

    AtCoder Grand Contest 011 upd:这篇咕了好久,前面几题是三周以前写的... AtCoder Grand Contest 011 A - Airport Bus 翻译 有\( ...

  9. AtCoder Grand Contest 031 简要题解

    AtCoder Grand Contest 031 Atcoder A - Colorful Subsequence description 求\(s\)中本质不同子序列的个数模\(10^9+7\). ...

随机推荐

  1. Python代码阅读(第21篇):将变量名称转换为蛇式命名风格

    Python 代码阅读合集介绍:为什么不推荐Python初学者直接看项目源码 本篇阅读的代码实现将变量名称转换为蛇式命名风格(snake case)的功能. 本篇阅读的代码片段来自于30-second ...

  2. 实现服务器和客户端数据交互,Java Socket有妙招

    摘要:在Java SDK中,对于Socket原生提供了支持,它分为ServerSocket和Socket. 本文分享自华为云社区<Java Socket 如何实现服务器和客户端数据交互>, ...

  3. Netty学习笔记(1)NIO三大组件

    1. Channel channel 有一点类似于 stream,它就是读写数据的双向通道,可以从 channel 将数据读入 buffer,也可以将 buffer 的数据写入 channel,而之前 ...

  4. [no code] Scrum Meeting 博客目录

    项目 内容 2020春季计算机学院软件工程(罗杰 任健) 2020春季计算机学院软件工程(罗杰 任健) 作业要求 Scrum Meeting博客目录 我们在这个课程的目标是 远程协同工作,采用最新技术 ...

  5. [HNOI2009]双递增序列(洛谷P4728)+小烈送菜(内部训练题)——奇妙的dp

    博主学习本题的经过嘤嘤嘤: 7.22 : 听学长讲(一知半解)--自己推(推不出来)--网上看题解--以为自己会了(网上题解是错的)--发现错误以后又自己推(没推出来)--给学长发邮件--得到正确解法 ...

  6. DP接口中AUX

    背景技术: DP接口(DisplayPort)是一种图像显示接口,它不仅可以支持全高清显示分辨率(1920×1080),还能支持4k分辨率(3840×2160),以及最新的8k分辨率(7680×432 ...

  7. spring mvc 原理(快速理解篇)

    这两张图大家应该都不陌生. 从图上来看就是:一个请求过来,front controller根据具体的请求路径分派到具体的controller,具体的controller处理请求并把处理结果返回给fro ...

  8. 力扣 - 剑指 Offer 67. 把字符串转换成整数

    题目 剑指 Offer 67. 把字符串转换成整数 思路1 根据题意,要解决这题,首先要判断的条件有: 不包括首位空格 第一位必须为:+.-.数字三者其一,否则不合法 数字必须连续的,如果遇到非数字, ...

  9. python基础数据类型语法

    #标识符:我们自己在写代码的时候,取的名字.#项目名 project name#包名 package name#模块名 .py ptthon文件名#规范:由字母数字下划线组成,但不能以数字#简明知意: ...

  10. 【mysql3】我的大学teacher课程进行中|持续更新系列!

    1.做一下powerdesigner的画图 2.所有的创建表格 .....1 修改字段的数据类型:alter table 表名 modify 字段名 新数据类型; 修改字段名: alter table ...