题目链接

BZOJ1407

题解

枚举\(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;
}

最新文章

  1. 实现ASP.NET无刷新下载并提示下载完成
  2. asp.net mvc 多级目录结构
  3. SQL多条件查询安全高效比较
  4. spring事物的传播行为
  5. java.lang.Math中的基本方法
  6. HTML5 Canvas 的事件处理---转
  7. JS--Div中数据滚动到最后一条重新从头开始滚动
  8. Linux man 后面的数字含义及作用
  9. javascript函数apply和call
  10. php中的require-once
  11. python2.5_1.5_通过指定的端口和协议找到服务名
  12. TRIZ系列-创新原理-28-替代机械系统原理
  13. 【View层】界面绘制
  14. ES6-01:常量与变量的声明
  15. [进程管理]Linux进程状态解析之R、S、D
  16. centOS7网络配置(nmcli,bonding,网络组)
  17. 织梦调用seotitle
  18. python 高级部分精华--那些书本不会告诉你的坑
  19. C语言编译器CL.exe
  20. 【原创】Proxmark3系列教程1——PM3用法

热门文章

  1. Java源码解析——集合框架(三)——Vector
  2. mysql计算排名
  3. jenkins邮件发送jmeter接口测试报告
  4. Fabric go sdk初始化所需证书解析
  5. (数据科学学习手札21)sklearn.datasets常用功能详解
  6. awk用法介绍
  7. 台湾ML笔记--1.2 formalize the learning probelm
  8. 【JS笔记】闭包
  9. 用es6写一个分数库
  10. 发布npm包 登录报错 E409 Conflict