题解 P2421 【[NOI2002]荒岛野人】
时间:2020-04-25
本文章向大家介绍题解 P2421 【[NOI2002]荒岛野人】,主要包括题解 P2421 【[NOI2002]荒岛野人】使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
我的第一道数论紫题
首先,我们先看两个野人,他们相遇的充要条件是
\(C_i+P_i\times k\equiv C_j+P_j\times k\;(mod\;M)\) 其中\(k\)是第几年,且\(k\ge L_i\;and\;L_j\)
这个式子还是没有办法直接求解,我们对它进行如下变形
\(C_i+P_i\times k-C_j-P_j\times k=bM\)
\(k\times(P_j-P_i)+bM=C_i-C_j\)
令\(a=P_j-P_i,c=C_i-C_j\)
转化为\(ak+bM=c\)
用扩展欧几里得求解这个应该都知道吧
其中\(k,M\)是变量
我们对于每一个\(M\),只需要枚举每两个野人,只有他们对应的\(k\)都符合要求时,这个\(M\)便是可行的。
由于\(M\le10^6\)直接枚举即可\(AC\)
\(Code\)
#include <cstdio>
#include <iostream>
using namespace std;
const int maxn=20,maxm=1e6;
int l[maxn],p[maxn],c[maxn];
int n,m;
int exgcd(int a,int b,int &x,int &y)
{
if(!b) {x=1;y=0;return a;}
int ans=exgcd(b,a%b,x,y),t=x;
x=y;y=t-a/b*y;
return ans;
}
bool check(int i,int j,int b)
{
int a=p[j]-p[i],d=c[i]-c[j],x,y;
if(a<0) a=-a,d=-d;
int gcd=exgcd(a,b,x,y);
if(d%gcd) return 1;
return ((x*(d/gcd)%(b/gcd)+(b/gcd))%(b/gcd))>min(l[i],l[j]);
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%d%d%d",c+i,p+i,l+i),m=max(m,c[i]);
for(int i=m;i<=maxm;i++)
{
bool fg=1;
for(int j=1;j<=n&&fg;j++)
for(int k=1;k<=n&&fg;k++)
if(k!=j) if(!check(j,k,i)) fg=0;
if(fg)
{
printf("%d\n",i);
break;
}
}
return 0;
}
原文地址:https://www.cnblogs.com/gxm123/p/12774285.html
- Gitlab删库事件回顾,备份手段还停留在“原始社会”?
- ASM 翻译系列第三十二弹:自制数据抽取小工具
- WordPress集成SendCloud邮件代发,规避SMTP泄漏网站主机真实IP的风险
- ASM 翻译系列第三十三弹:REQUIRED_MIRROR_FREE_MB的含义
- 放弃Python转向Go语言:这9大理由就够了 !(附代码)
- CCKiller:Linux轻量级CC攻击防御工具,秒级检查、自动拉黑和释放
- 利用HSTS安全协议柔性解决全站HTTPS的兼容性问题
- Nginx内容替换模块http_substitutions_filter_module及实用案例分享
- libmemcached编译安装报错解决记录
- 解决网站静态缓存后WP-PostViews插件不计数的问题
- Haproxy安装部署文档及多配置文件管理方案
- ASM 翻译系列第三十四弹:ASM磁盘组重要属性介绍
- 博客集成Hitokoto·一言经典语句功能
- 博客网页导致电脑CPU飙升的问题解决记录
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 自动采集各种美女图片站并下载图和自动搭建图片站
- 修改其他函数的功能的神器——python装饰器
- AllTube:视频解析下载源码安装教程
- Zsh和Oh My Zsh的安装配置
- 程序猿怎么利用技术挣钱?——python量化实践
- 利用WireGuard建立IPv6隧道
- selenium爬虫相关报错解决
- 小涴熊漫画CMS:非常不错的免费开源的漫画连载系统,带采集API
- 成都电信宽带获取IPV6地址全过程
- android studio 3.6.1导入项目报错提示无法下载classpath里的内容
- Linux VPS使用命令行快速查询百度网盘提取码
- Flutter 首页必用组件NestedScrollView的示例详解
- AUXPI:简单的API图床程序,支持上传到搜狗/新浪/SMMS等多个图床
- android使用TextView实现跑马灯效果
- Android 自定义 View 中使用 Spannable的实例详解