BZOJ1407 [Noi2002]Savage 【扩展欧几里得】
2024-10-20 01:31:59
题目链接
题解
枚举\(m\)用扩欧判即可
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#define REP(i,n) for (int i = 1; i <= (n); i++)
using namespace std;
const int maxn = 20,maxm = 100005,INF = 1000000000;
inline int read(){
int out = 0,flag = 1; char c = getchar();
while (c < 48 || c > 57){if (c == '-') flag = -1; c = getchar();}
while (c >= 48 && c <= 57){out = (out << 3) + (out << 1) + c - 48; c = getchar();}
return out * flag;
}
int C[maxn],P[maxn],L[maxn],n;
inline void exgcd(int a,int b,int& d,int& x,int& y){
if (!b){d = a; x = 1; y = 0;}
else exgcd(b,a % b,d,y,x),y -= (a / b) * x;
}
inline bool ok(int u,int v,int m){
int a = P[u] - P[v],b = m,c = C[v] - C[u],d,x,y;
exgcd(a,b,d,x,y);
if (c % d) return true;
b = abs(b / d);
x = (x * c / d) % b;
if (x <= 0) x += b;
return x > min(L[u],L[v]);
}
inline bool check(int m){
for (register int i = 1; i < n; i++)
for (register int j = i + 1; j <= n; j++){
if (!ok(i,j,m)) return false;
}
return true;
}
int main(){
n = read(); int Max = 0;
bool tag = true;
REP(i,n){
C[i] = read(),P[i] = read(),L[i] = read(),Max = max(Max,C[i]);
C[i]--;
if (P[i] != 1) tag = false;
}
if (tag){printf("%d",Max); return 0;}
for (register int m = Max; ; m++){
if (check(m)) {printf("%d\n",m); return 0;}
}
return 0;
}
最新文章
- 实现ASP.NET无刷新下载并提示下载完成
- asp.net mvc 多级目录结构
- SQL多条件查询安全高效比较
- spring事物的传播行为
- java.lang.Math中的基本方法
- HTML5 Canvas 的事件处理---转
- JS--Div中数据滚动到最后一条重新从头开始滚动
- Linux man 后面的数字含义及作用
- javascript函数apply和call
- php中的require-once
- python2.5_1.5_通过指定的端口和协议找到服务名
- TRIZ系列-创新原理-28-替代机械系统原理
- 【View层】界面绘制
- ES6-01:常量与变量的声明
- [进程管理]Linux进程状态解析之R、S、D
- centOS7网络配置(nmcli,bonding,网络组)
- 织梦调用seotitle
- python 高级部分精华--那些书本不会告诉你的坑
- C语言编译器CL.exe
- 【原创】Proxmark3系列教程1——PM3用法