Codeforces.1041F.Ray in the tube(思路)
\(Description\)
有两条平行于\(x\)轴的直线\(A,B\),每条直线上的某些位置有传感器。你需要确定\(A,B\)轴上任意两个整点位置\(x_A,x_B\),使得一条光线沿\(x_A\to x_B\)射出(碰到\(A,B\)后反射),能够碰到的传感器数量最多是多少。
每条直线上的传感器数量\(\leq10^5,\ 0\leq x_i\leq 10^9\)。
\(Solution\)
由光的反射定律可知,光束接触直线的相邻两个点的水平距离是确定的,设这个距离为\(dx\)(纵坐标就没有什么用了)。
那么会被从\(x_A\)出发的光束照到的点,在\(A\)轴上满足坐标为\(x_A+2k\cdot dx\);在\(B\)轴上满足坐标为\(x_A+(2k-1)\cdot dx\)。
我们发现若\(dx=a\cdot b\),\(a\)为奇数,\(b\)为\(1\)或偶数,则选\(dx'=\frac{dx}{a}=b\)会碰到所有\(dx\)会碰到的点,即不会更差。
换句话说就是,所有 \(dx=奇数\) 可以被 \(dx'=1\) 取代,\(dx=偶数\) 可以被 \(dx'=某个2的幂\) 取代。
所以存在(除\(1\)外的)奇数因子的\(dx\)没有必要判断。那么我们只需要判断\(dx=2^l,l\geq 0\)的情况。这一共有\(\log(10^9)\)种。
对于一个确定的\(dx\),如果\(A\)轴上两个点\(x_1,x_2\)同时被碰到,那么满足\(x_1\equiv x_2\mod{(2 \cdot dx)}\);
如果选了\(A\)轴上的\(x_1\),\(B\)轴上的一个点\(x_2\)想要被碰到,就要满足\(x_1+dx\equiv x_2\mod{(2 \cdot dx)}\)。
所以我们把\(A\)点集中的每个\(x_i\)对\(2dx\)取模,\(B\)组中的每个\(x_i\)减掉一个\(dx\)再对\(2dx\)取模)。
然后把余数相同的分为一组,点数最多的一组就是当前最优解。
sort或直接map都可以。
复杂度\(O(n\log n\log(10^9))\)。
注意\(ans\)初始是\(2\)。。
//171ms 1500KB
#include <cstdio>
#include <cctype>
#include <algorithm>
//#define gc() getchar()
#define MAXIN 150000
#define gc() (SS==TT&&(TT=(SS=IN)+fread(IN,1,MAXIN,stdin),SS==TT)?EOF:*SS++)
const int N=2e5+5;
int n,A[N],tmp[N],Now;
char IN[MAXIN],*SS=IN,*TT=IN;
inline int read()
{
int now=0;register char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);now=now*10+c-'0',c=gc());
return now;
}
int main()
{
int n=read(); read();
for(int i=1; i<=n; ++i) A[i]=read();
int m=read(),tot=n+m; read();
for(int i=n+1; i<=tot; ++i) A[i]=read();
int ans=2/*!*/; tmp[tot+1]=2e9+1;
for(int dx=1; dx<=int(1e9); dx<<=1)
{
int mod=dx<<1;
for(int i=1; i<=n; ++i) tmp[i]=A[i]%mod;
for(int i=n+1; i<=tot; ++i) tmp[i]=(A[i]+dx)%mod;
std::sort(tmp+1,tmp+1+tot);
for(int i=1,las=1; i<=tot; ++i)
if(tmp[i+1]!=tmp[i]) ans=std::max(ans,i-las+1), las=i+1;
}
printf("%d\n",ans);
return 0;
}
Codeforces.1041F.Ray in the tube(思路)的更多相关文章
- Codeforces 1041F Ray in the tube (看题解)
Ray in the tube 感觉是套路题.. 如果确定一个差值x我们如何取确定答案呢, 我们把a[ i ] -> a[ i ] % (2 * x), 把b[ i ] -> (b[ i ...
- L - Ray in the tube Gym - 101911L (暴力)
---恢复内容开始--- You are given a tube which is reflective inside represented as two non-coinciding, but ...
- CF 1041 F. Ray in the tube
F. Ray in the tube 链接 题意: 有两条平行于x轴的直线A,B,每条直线上的某些位置有传感器.你需要确定A,B轴上任意两个整点位置$x_a$,$x_b$,使得一条光线沿$x_a→x_ ...
- Codeforces | CF1041F 【Ray in the tube】
昨天晚上全机房集体开\(Div2\),因为人傻挂两次\(B\)题的我开场就\(rank2000+\dots qwq\)于是慌乱之中的我就开始胡乱看题(口胡),于是看了\(F\dots\)(全机房似乎也 ...
- Codeforces Round #509 (Div. 2) F. Ray in the tube(思维)
题目链接:http://codeforces.com/contest/1041/problem/F 题意:给出一根无限长的管子,在二维坐标上表示为y1 <= y <= y2,其中 y1 上 ...
- codeforces 724c Ray Tracing
好题 原题: There are k sensors located in the rectangular room of size n × m meters. The i-th sensor is ...
- Sereja and Brackets CodeForces - 380C (线段树+分治思路)
Sereja and Brackets 题目链接: CodeForces - 380C Sereja has a bracket sequence s1, s2, ..., *s**n, or, in ...
- codeforces 630C - Lucky Numbers 递推思路
630C - Lucky Numbers 题目大意: 给定数字位数,且这个数字只能由7和8组成,问有多少种组合的可能性 思路: 假设为1位,只有7和8:两位的时候,除了77,78,87,88之外还哇哦 ...
- [CF1041F Ray in the tube][数学]
http://codeforces.com/contest/1041/problem/F 题目大意: 下边界有n个给定点,上边界有m个给定点,可以从任意一个点发出一条激光,激光碰到边界会反射 激光到达 ...
随机推荐
- CCNA学习与实验指南——第2章 网络互联和参考模型
大三下学期的这个时间段,不知道是不是社会就业的恐惧与自身前途的迷茫所带来的压力,身边的同学一个个的整天奔赴考研室学的好不努力,空荡荡的宿舍只剩我一人孑然聊聊甚是索然无味,亦或许是即将毕业的压力等接踵而 ...
- UnicodeDecodeError gbk codec can't decode byte in position illegal multibyte sequence
UnicodeDecodeError:'gbk' codec can't decode byte in position : illegal multibyte sequence 觉得有用的话,欢迎一 ...
- Codeforces 931 C. Laboratory Work
http://codeforces.com/problemset/problem/931/C 题意: 给定一个数列,要求构造一个等长的数列,使得数列的平均值等于给定数列,并且使得构造出的数列中与原数列 ...
- Lua程序设计(二)面向对象概念介绍
----------------------------------------------------------- Lua面向对象3 local smartMan = { name = " ...
- 20155226 2016-2017-2 《Java程序设计》第6周学习总结
20155226 2016-2017-2 <Java程序设计>第6周学习总结 教材学习内容总结 第十章 输入/输出 10.1 InputStream与OutputStream 1 . 串流 ...
- C 语言结构体之点运算符( . )和箭头运算符( -> )的区别
很多时候,在对结构体进行相应的编码时,时而发现是用点运算符( . ),时而是用箭头运算符( -> ):那么这两者之间的使用有什么区别么? 相同点:两者都是二元操作符,而且右边的操作数都是成员的名 ...
- 基础图像处理之混合空间增强——(Java:拉普拉斯锐化、Sobel边缘检测、均值滤波、伽马变换)
相信看过冈萨雷斯第三版数字图像处理的童鞋都知道,里面涉及到了很多的基础图像处理的算法,今天,就专门借用其中一个混合空间增强的案例,来将常见的几种图像处理算法集合起来,看能发生什么样的化学反应 首先,通 ...
- Nuts & Bolts Problem
Given a set of n nuts of different sizes and n bolts of different sizes. There is a one-one mapping ...
- Linux中断(interrupt)子系统之五:软件中断(softIRQ)
转自:http://blog.csdn.net/droidphone/article/details/7518428 软件中断(softIRQ)是内核提供的一种延迟执行机制,它完全由软件触发,虽然说是 ...
- Linux中断(interrupt)子系统之四:驱动程序接口层 & 中断通用逻辑层【转】
转自:http://blog.csdn.net/droidphone/article/details/7497787 在本系列文章的第一篇:Linux中断(interrupt)子系统之一:中断系统基本 ...