BZOJ-1407 Savage 枚举+拓展欧几里得(+中国剩余定理??)
zky学长实力ACM赛制测试,和 大新闻(YveH) 和 华莱士(hjxcpg) 组队。。。2h 10T,开始 分工我搞A,大新闻B,华莱士C,于是开搞;
然而第一题巨鬼畜,想了40min发现似乎不可做(人傻),然而BC也在搞。。。于是开始做第四道;
大约1h10’ B题A了。。1h30' C题也A了= =;
后来去搞F,公式推得很快,并且很自信是对的。。于是筛!搞!,一交 TLE?!,然后意识到 结果可以直接筛,可以省去搞得过程
不虚,改!!然后时间到了。。。毫无贡献的傻逼一个。。。。可怕。
于是搞了下第四题D:
1407: [Noi2002]Savage
Time Limit: 5 Sec Memory Limit: 64 MB
Submit: 1128 Solved: 513
[Submit][Status][Discuss]
Description
Input
第1行为一个整数N(1<=N<=15),即野人的数目。第2行到第N+1每行为三个整数Ci, Pi, Li (1<=Ci,Pi<=100, 0<=Li<=106 ),表示每个野人所住的初始洞穴编号,每年走过的洞穴数及寿命值。
Output
仅包含一个数M,即最少可能的山洞数。输入数据保证有解,且M不大于106。
Sample Input
3
1 3 4
2 7 3
3 2 1
Sample Output
6
该样例对应于题目描述中的例子。
HINT
Source
分析:
此题但是想到是方程组,于是直接往中国剩余定理上想了。。事后发现其实只需要 解线性的同余方程 即可,仅仅需要拓展欧几里得。。
枚举m,然后利用拓欧进行判定。
首先发现规律:(loc为初始洞穴,mov为移动数,ans为相撞所需年数,m为洞穴数)
loc【i】+mov【i】*ans=loc【j】+mov【j】*ans (mod m)
于是移项得:
(mov【i】-mov【j】) *ans=loc【j】-loc【i】 (mod m)
判定即可;
值得注意的几个小地方:
为了取模的方便,可以把初始的洞穴序号-1;
题目并不符合二分的性质,当然数据范围,枚举绝对可行;
转成不定方程后,mov【i】-mov【j】与m未必互质,所以应该先同除一个gcd;
最后,如果有解,且解<=lif【i】、lif【j】(寿命年份)即不可行;
(偶对,似乎网上有用中国剩余定理解得。。然而我当时并不能想出来,人傻╮(╯▽╰)╭)
坑了我自己的一个地方。。
这破地方开始没注意于是坑了近10分钟。。
code:
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int n;
int loc[20],mov[20],lif[20];
int st=0;
int x,y;int gcd;
void exgcd(int a,int b,int &x,int &y,int &gcd)
{
if (b==0) {gcd=a; x=1; y=0; return;}
exgcd(b,a%b,y,x,gcd);
y-=a/b*x;
}
bool check(int m)
{
for (int i=1; i<=n-1; i++)
for (int j=i+1; j<=n; j++)
{
int dloc=((loc[j]-loc[i])%m+m)%m;
int dmov=((mov[i]-mov[j])%m+m)%m;
exgcd(dmov,m,x,y,gcd);
if ((dloc%gcd)!=0) continue;
dloc/=gcd;
int mm=m/gcd;int ans=(dloc*x%mm+mm)%mm;
if (ans<=lif[i] && ans<=lif[j]) return false;
}
return true;
}
int main()
{
scanf("%d",&n);
for (int i=1; i<=n; i++)
{
scanf("%d%d%d",&loc[i],&mov[i],&lif[i]);
st=max(st,loc[i]);loc[i]--;
}
for (int i=st;;i++)
if (check(i)) {printf("%d\n",i);break;}
return 0;
}
BZOJ-1407 Savage 枚举+拓展欧几里得(+中国剩余定理??)的更多相关文章
- [P1516]青蛙的约会 (扩展欧几里得/中国剩余定理?)
每日做智推~ 一看就是一道数学题. 再看是一道公约数的题目. 标签是中国孙子定理. 题解是扩展欧几里得 (笑) 一开始没看数据范围 只有50分 开一个longlong就可以了 #include< ...
- 【lydsy1407】拓展欧几里得求解不定方程+同余方程
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1407 题意: 有n个野人,野人各自住在第c[i]个山洞中(山洞成环状),每年向前走p[i] ...
- BZOJ-2242 计算器 快速幂+拓展欧几里得+BSGS(数论三合一)
污污污污 2242: [SDOI2011]计算器 Time Limit: 10 Sec Memory Limit: 512 MB Submit: 2312 Solved: 917 [Submit][S ...
- [zoj 3774]Power of Fibonacci 数论(二次剩余 拓展欧几里得 等比数列求和)
Power of Fibonacci Time Limit: 5 Seconds Memory Limit: 65536 KB In mathematics, Fibonacci numbe ...
- UVA.12169 Disgruntled Judge ( 拓展欧几里得 )
UVA.12169 Disgruntled Judge ( 拓展欧几里得 ) 题意分析 给出T个数字,x1,x3--x2T-1.并且我们知道这x1,x2,x3,x4--x2T之间满足xi = (a * ...
- POJ.2142 The Balance (拓展欧几里得)
POJ.2142 The Balance (拓展欧几里得) 题意分析 现有2种质量为a克与b克的砝码,求最少 分别用多少个(同时总质量也最小)砝码,使得能称出c克的物品. 设两种砝码分别有x个与y个, ...
- Modular Inverse (拓展欧几里得求逆元)
The modular modular multiplicative inverse of an integer a modulo m is an integer xsuch that a-1≡x ( ...
- Codeforces Round #451 (Div. 2) B. Proper Nutrition【枚举/扩展欧几里得/给你n问有没有两个非负整数x,y满足x·a + y·b = n】
B. Proper Nutrition time limit per test 1 second memory limit per test 256 megabytes input standard ...
- NOIP2012拓展欧几里得
拉板题,,,不说话 我之前是不是说过数据结构很烦,,,我想收回,,,今天开始的数论还要恶心,一早上听得头都晕了 先来一发欧几里得拓展裸 #include <cstdio> void gcd ...
随机推荐
- FreeMarker 一二事 - 静态模板的使用与生成
如今前后端分离,动静分离 使用freemarker实现动静分离,nginx处理静态资源文件,提高效率 加载jar包 <!-- freemarker --> <dependency&g ...
- MySQL数据库学习笔记(十一)----DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- JavaWeb学习----JSP简介及入门(含Eclipse for Java EE及Tomcat的配置)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...
- java 20 -10 字节流四种方式复制mp3文件,测试效率
电脑太渣,好慢..反正速率是: 高效字节流一次读写一个字节数组 > 基本字节流一次读写一个字节数组 > 高效字节流一次读写一个字节 > 基本字节流一次读写一个字节 前两个远远快过后面 ...
- java 20 - 4 IO流概述和一个简单例子解析
IO流的分类: 流向: 输入流 读取数据 输出流 写出数据 数据类型: 字节流 字节输入流 读取数据 InputStream 字节输出流 写出数据 OutputStream 字符流 字符 ...
- Android优化——UI优化(三)使用ViewStub延迟加载
使用ViewStub延迟加载 1.ViewStub延迟加载 ViewStub是一个不可见的,大小为0的View,最佳用途就是实现View的延迟加载,在需要的时候再加载View,可Java中常见的性能优 ...
- Iron man
儿子的手办在近期又新增一套钢铁侠,来自于淘宝的玩具推荐,这个推荐也得益于小美和他平日在淘宝商城里的各种玩具浏览,充分体现了现阶段对复仇者联盟成员的喜爱. 一套共六个,有着不同的颜色,但造型基本一致带L ...
- 一个DOM元素绑定多个事件时,先执行冒泡还是捕获
绑定在被点击元素的事件是按照代码顺序发生,其他元素通过冒泡或者捕获“感知”的事件,按照W3C的标准,先发生捕获事件,后发生冒泡事件.所有事件的顺序是:其他元素捕获阶段事件 -> 本元素代码顺序事 ...
- linux vmstat 系统结果说明
可以用vmstat 显示系统负载等信息. 例如 vmstat 5 5,表示在T(5)秒时间内进行N(5)次采样. procs:r-->;在运行队列中等待的进程数b-->;在等待io的进程数 ...
- sqlalchemy 的 raw sql 方式使用示例
#获取数据库 from sqlalchemy import create_engine db = create_engine("sqlite:///:memory:", echo= ...