洛谷 P1495 曹冲养猪
这是一道标准的孙子定理的题,题意浅显,思路明确
然后我就交了整整16遍啊,欺负人啊,题解暴力就能过,我就TLE
。。悲惨的提交记录



下面是题面
题目描述
自从曹冲搞定了大象以后,曹操就开始捉摸让儿子干些事业,于是派他到中原养猪场养猪,可是曹冲满不高兴,于是在工作中马马虎虎,有一次曹操想知道母猪的数量,于是曹冲想狠狠耍曹操一把。举个例子,假如有16头母猪,如果建了3个猪圈,剩下1头猪就没有地方安家了。如果建造了5个猪圈,但是仍然有1头猪没有地方去,然后如果建造了7个猪圈,还有2头没有地方去。你作为曹总的私人秘书理所当然要将准确的猪数报给曹总,你该怎么办?
输入输出格式
输入格式:
第一行包含一个整数n (n <= 10) – 建立猪圈的次数,解下来n行,每行两个整数ai, bi( bi <= ai <= 1000), 表示建立了ai个猪圈,有bi头猪没有去处。你可以假定ai,aj互质.
输出格式:
输出包含一个正整数,即为曹冲至少养母猪的数目。
输入输出样例
输入样例
3
3 1
5 1
7 2
输出样例
16
题目已经描述的非常清晰了
先上90分代码,根据代码进行讲解
#include<iostream>
#include<cstdio>
#define ll __int128 //实际上开long long也能过,我后来试过了,当时因为怀疑long long不够,多此一举
#define re register //可耻的register也并没有使我A掉最后一个点
using namespace std;
const int maxn=15;
int n,a[maxn],b[maxn];
ll tot=1,ans; //tot即所有数乘积,使用时除以当前数即可,避免多次计算浪费时间
void read(int& a){ //毫无意义的快读
a=0;re char p;
p=getchar();
while(p>'9'||p<'0')
p=getchar();
while(p>='0'&&p<='9'){
a=(a<<3)+(a<<1)+(p^48);
p=getchar();
}
return;
}
void print(ll a){ //为int_128写的输出,一般用不到
if(a==0){
printf("0");
return;
}
string pp="";
while(a){
pp+=a%10+'0';
a/=10;
}
for(int i=pp.size()-1;i>=0;i--)printf("%c",pp[i]);
}
int main(){
read(n);
for(re int i=1;i<=n;++i){
read(a[i]),read(b[i]);
tot*=a[i];
}
for(re int i=1;i<=n;++i){
re ll p=tot/a[i],sum=p;
while(sum%a[i]!=1) //求其余数的公倍数,使其取模当前数余1
sum+=p;
ans=(ans+b[i]*sum)%tot;
}
print(ans);
return 0;
}
因为有暴力那一块,无论怎么优化都A不了(如果有哪位大佬能优化A掉,请私信我,情愿被打脸)
于是乎,将暴力推改为直接扩欧解同余方程,一次AC
下放满分代码
#include<iostream>
#include<cstdio>
#define ll __int128
#define re register
using namespace std;
const int maxn=15;
int n,a[maxn],b[maxn];
ll tot=1,ans;
void read(int& a){
a=0;re char p;
p=getchar();
while(p>'9'||p<'0')
p=getchar();
while(p>='0'&&p<='9'){
a=(a<<3)+(a<<1)+(p^48);
p=getchar();
}
return;
}
void print(ll a){
if(a==0){
printf("0");
return;
}
string pp="";
while(a){
pp+=a%10+'0';
a/=10;
}
for(int i=pp.size()-1;i>=0;i--)printf("%c",pp[i]);
}
ll e_gcd(ll a,ll b,ll &x,ll &y){ //就是这里,解同余方程
if(b==0){
x=1;y=0;
return a;
}
ll ans=e_gcd(b,a%b,x,y);
ll temp=x;
x=y;
y=temp-a/b*y;
return ans;
}
ll cal(ll a,ll b){
ll x,y;
ll gcd=e_gcd(a,b,x,y);
if(1%gcd!=0)return -1;
x*=1/gcd;
return (x%b+b)%b;
}
int main(){
read(n);
for(re int i=1;i<=n;++i){
read(a[i]),read(b[i]);
tot*=a[i];
}
for(re int i=1;i<=n;++i){
re ll p=tot/a[i];
ans=(ans+b[i]*p*cal(p,a[i]))%tot;
}
print(ans);
return 0;
}
洛谷 P1495 曹冲养猪的更多相关文章
- [洛谷P1495] 曹冲养猪 (中国剩余定理模板)
中国剩余定理(朴素的)用来解线性同余方程组: x≡a[1] (mod m[1]) x≡a[2] (mod m[2]) ...... x≡a[n] (mod m[n]) 定义ms=m[1]*m[2]*. ...
- 【题解】洛谷P1495 曹冲养猪 (中国剩余定理)
洛谷P1495:https://www.luogu.org/problemnew/show/P1495 思路 建立了a个猪圈 有b头猪没有去处 即x≡b(mod a) x即是ans 把所有的关系全部列 ...
- 洛谷——P1495 曹冲养猪
题目描述 自从曹冲搞定了大象以后,曹操就开始捉摸让儿子干些事业,于是派他到中原养猪场养猪,可是曹冲满不高兴,于是在工作中马马虎虎,有一次曹操想知道母猪的数量,于是曹冲想狠狠耍曹操一把.举个例子,假如有 ...
- P1495 曹冲养猪(拓展欧几里得)
题目描述 自从曹冲搞定了大象以后,曹操就开始捉摸让儿子干些事业,于是派他到中原养猪场养猪,可是曹冲满不高兴,于是在工作中马马虎虎,有一次曹操想知道母猪的数量,于是曹冲想狠狠耍曹操一把.举个例子,假如有 ...
- P1495 曹冲养猪
原题链接 https://www.luogu.org/problemnew/show/P1495 这个题明显的中国剩余定理(孙子定理),如果有不懂孙子定理的点这个链接https://baike.bai ...
- [Luogu P1495]曹冲养猪
题目链接 中国剩余定理(孙子定理)的裸题.直接放代码. #include<iostream> #include<cstdio> #include<algorithm> ...
- luogu P1495 曹冲养猪(中国剩余定理)
题意 题解 翻到了一个金句 就跟这句话说得一样,就是个裸题. 所以看模板呗. #include<iostream> #include<cstring> #include< ...
- 洛谷1640 bzoj1854游戏 匈牙利就是又短又快
bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...
- 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.
没有上司的舞会 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...
随机推荐
- day2 self __init__ __str__
1 self 谁调用指向谁自己 相当于其他语言的this #1.类名 class Cat(): #大驼峰的命名规范 #2.类的属性 #3.类的方法 def eat(self): print(&qu ...
- [Vani有约会]雨天的尾巴 线段树合并
[Vani有约会]雨天的尾巴 LG传送门 线段树合并入门好题. 先别急着上线段树合并,考虑一下这题的暴力.一看就是树上差分,对于每一个节点统计每种救济粮的数量,再一遍dfs把差分的结果统计成答案.如果 ...
- 前端 CDNJS 库及 Google Fonts、Ajax 和 Gravatar 国内加速服务
由于某些众所周知的原因,好多开源的 JS 库采用的国外 CDN 托管方式在国内访问速度不如人意.所以我们特意制作了这个公益项目,托管了 CDNJS 的所有开源 JS 库以及反代了 Google Fon ...
- MantisBT导出Excel文件名显示中文的修改方法
我安装的是 mantisbt-2.15.0. 在“查看问题”页面导出Excel文件后,其文件名虽然是我选择的项目名称,但是,若项目名称中有中文,这就是用%加编码显示. 解决方法是: 在 <Ma ...
- Update类型_JDBC的方法_JAVA方法_Loadrunner脚本
java vuser JDBC 参数化的方法 如果不进行参数化 直接把32 33行去掉 ,sql 值写到valuers 中就行了 下面这是 insert,delete,update 三种方法 ...
- 【坚持】Selenium+Python学习之从读懂代码开始 DAY1
学习Selenium+Python已经好几个月了,但越学发现不懂的东西越多. 感觉最大的问题还是在于基础不扎实,决定从头开始,每天坚持读代码,写代码. 相信量变一定能到质变!!! 2018/05/09 ...
- Centos6升级至openssh-7.5p1
最近公司有几台服务器需要搬至甲方(政府单位),所以在安装服务时用的是16年的openssh7.3pl, 今天通知我们有漏洞,需要再一次升级,看到官方文档上版本已升级至7.5,所以干脆直接搞7.5 具体 ...
- UVA 11542 高斯消元
从数组中选择几个数,要求他们的乘积可以开平方,问有多少种方案. 先将单个数拆分成质因子,对于这个数而言,那些指数为奇数的质因子会使这个数无法被开平方. 所以我们需要选择一个对应质因子指数为奇数的元素, ...
- HTML5+Bootstrap 学习笔记 4
HTML5 <map> <area> 标签 <map> 标签定义客户端的图像映射.图像映射是带有可点击区域的图像. <area> 标签定义图像映射内部的 ...
- mysql优化建议21条
转自: http://blog.csdn.net/waferleo/article/details/7179009 今 天,数据库的操作越来越成为整个应用的性能瓶颈了,这点对于Web应用尤其明显.关于 ...