洛谷 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.他们有 ...
随机推荐
- combotree -下拉框树异步加载
问题: 下拉树数据比较多时,全加载会产生页面延迟,需要实现异步加载 方案: 点击事件加载:先加载部分,点击节点时再展开并追加子节点 onBeforeExpand事件:在展开树前加载,感觉这种方式比较优 ...
- Drupal views中实现两列布局
Views中的format有table,grid,unformatted list等,但是没有2 columns等选项. 如果要达到如下效果: 左侧一列有title,content,右侧一列image ...
- Jlink v8仿真器在64位系统上刷固件
1. 安装软件sam-ba_2.16.exe.本次主要是Jlink v8在64位系统下面的刷固件方法. 2. J-link通过USB连接至电脑,短接PCB上标号为ERASE的焊盘5秒,断开ERASE两 ...
- dsp6657的helloworld例程测试-第一篇
环境搭建可以参考http://blog.sina.com.cn/s/blog_ed2e19900102xi2j.html 1. 先从mcsdk导入工程,helloworld例程 2. 提示有错误,估计 ...
- TPO 03 - Architecture
TPO 03 - Architecture Architecture is the art and science of designing structures that[主语是Architectu ...
- hdfs遍历文件方法
import org.apache.commons.lang.StringUtils; import org.apache.hadoop.conf.Configuration; import org. ...
- python编辑购物车
一.需求分析 输入工资金额,进入购物车,并打印输出商品编号和价格,用户可以通过输入商品编号进行商品选购 余额不足时,打印提示信息 通过q进行退出结算 购物车能够循环购物 二.代码实现 ShoopCar ...
- python常用快捷键
最重要的快捷键1. ctrl+shift+A:万能命令行2. shift两次:查看资源文件 新建工程第一步操作1. module设置把空包分层去掉,compact empty middle packa ...
- Python基础灬列表&字典生成式
列表生成式 # 求1~10偶数的平方 # 1.常规写法 a_list = [] for i in range(1, 11): if i % 2 == 0: a_list.append(i * i) p ...
- win7重装系统后设置Python2.7环境
起因 台式机的主板莫名出现问题,显示器画面卡顿不能动,鼠标键盘无反应,在这种情况下只好按住电源键断电.下面重启后,显示器无画面,猜测开机后没有进BIOS.然后就拆机箱,拔下电源线后撬起主板电池几秒再放 ...