hdoj A/B 1576 (拓展欧几里得) 数学变换

来源:互联网 发布:数字校园平台软件 编辑:程序博客网 时间:2024/05/21 14:43

A/B

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 3341    Accepted Submission(s): 2535


Problem Description
要求(A/B)%9973,但由于A很大,我们只给出n(n=A%9973)(我们给定的A必能被B整除,且gcd(B,9973) = 1)。

Input
数据的第一行是一个T,表示有T组数据。
每组数据有两个数n(0 <= n < 9973)和B(1 <= B <= 10^9)。

Output
对应每组数据输出(A/B)%9973。

Sample Input
21000 5387 123456789

Sample Output
79226060
因为gcd(B,9973)=1,所以可得B*x+9973*y=1;
A/B=x; 则A=B*x;
因为A/9973=n;
则A=9973*y+n=B*x;
所以B*x-9973*y=n;
#include<stdio.h>#include<string.h>#define ll long longll gcd(ll a,ll b,ll &x,ll &y){if(!b){x=1;y=0;return a;}ll ans=gcd(b,a%b,x,y);ll tmp=x;x=y;y=tmp-a/b*y;return ans;}ll  val(ll a,ll b,ll c){ll x,y;ll d=gcd(a,b,x,y);if(c%d!=0)return -1;x*=c/d;b/=d;if(b<0)b=-b;ll ans=x%b;if(ans<=0)ans+=b;return ans;}int main(){int t;ll b,n;scanf("%d",&t);while(t--){scanf("%lld%lld",&n,&b);ll ans=val(b,9973,n);//if(ans==-1)  //题中没让判断没有的情况 //printf("Impossible\n");//elseprintf("%lld\n",ans);}return 0;}
//数学化简,枚举
#include<stdio.h>#include<string.h>int main(){int t;long long n,b;int i;scanf("%d",&t);while(t--){scanf("%lld%lld",&n,&b);for(i=0;i<9973;i++){if((b*i-n)%9973==0)break;}printf("%d\n",i);}return 0;} 


0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 电脑被压缩后电脑打不开怎么办 眼睛里进了飞虫怎么办 虫子飞到眼睛里怎么办 云电脑pc版双鼠标怎么办 电脑蓝屏代码7f怎么办 笔记本电脑蓝屏开不了机怎么办 装xp系统后蓝屏怎么办 一键ghost断电了怎么办 如何防止cpu降频怎么办 win7 64位系统不兼容怎么办 网页无法加载打印机插件怎么办 微信提示安装了插件怎么办 电脑上不了网怎么办 win10 win10电脑突然没网了怎么办 笔记本玩战争前线发热严重怎么办 玩战争前线总是闪退怎么办 uu加速器卡在29怎么办 新ipad下载不了东西怎么办 福昕pdf阅读器找不到图章怎么办 战地4没达到分数怎么办 植物在太暗环境怎么办 玩绝地求生机型不支持怎么办 安卓安装包损坏怎么办 方舟手游安装包损坏怎么办 7p新机耗电快怎么办 不小心把图片删了怎么办 腿上毛又长又多怎么办 征兵体检体重太轻怎么办 体检发现颈部有淋巴节怎么办? 4岁宝宝汗毛重怎么办 嘴巴张开闭不上怎么办 口张开闭不上怎么办 要去当兵有痔疮怎么办 狗舔的东西吃了怎么办 婚检说生过孩子怎么办 劳动法规定身体有疾病的怎么办 铁路对职工醉驾怎么办 入职体检高血糖怎么办 睾丸捏一下很疼怎么办 小孩睾丸受外力红肿该怎么办 睾丸炎症怎么办啊会不会不育呢