NOIP2012 同余方程 题解
2015-08-13 17:27
357 查看
描述
求关于x的同余方程ax ≡ 1 (mod b)的最小正整数解。
格式
输入格式
输入只有一行,包含两个正整数a, b,用一个空格隔开。输出格式
输出只有一行,包含一个正整数x0,即最小正整数解。输入数据保证一定有解。
样例1
样例输入1[复制]
3 10
样例输出1[复制]
7
限制
每个测试点1s
提示
对于40%的数据,2 ≤b≤ 1,000; 对于60%的数据,2 ≤b≤ 50,000,000;
对于100%的数据,2 ≤a, b≤ 2,000,000,000。
分析:
解同余方程,比较水
欧几里德算法
program mod1;
var
a,b,x,y:longint;
procedure gcd(a,b:longint);
var t:longint;
begin
if b<>0
then gcd(b,a mod b)
else begin
x:=1;
y:=0;
exit;
end;
t:=x;
x:=y;
y:=t-(a div b)*y;
end;
begin
readln(a,b);
gcd(a,b);
//writeln(x,' ',y);
writeln(((x mod b)+b)mod b);
end.
代码二:
program mod2;
procedure oujilide(a,b:int64;var d,x,y:int64);
begin
if b=0 then
begin
d:=a;
x:=1;
y:=0;
end
else
begin
oujilide(b,a mod b,d,y,x);
y:=y-x*(a div b);end;
end;
var
a,b,d,x,y:int64;
begin
assign(input,'mod.in');
reset(input);
assign(output,'mod.out');
rewrite(output);
readln(a,b);
oujilide(a,b,d,x,y);
while x<0 do
x:=x+b;
writeln(x);
close(input);
close(output);
end.
相关文章推荐
- SQLServer 2012中设置AlwaysOn解决网络抖动导致的提交延迟问题
- SQL Server 2012 创建定时作业(图文并茂,教你轻松快速创建)
- 关于visual studio 2012 update 2中的新功能介绍
- 配置yum源
- System Center 2012
- 北極冰層將在2012年夏天融冰季節結束前完全融化
- DC 2003直接升级到2012
- 2012十大热门云职业
- 2012,十大热门云职业
- 2012,十大热门云职业
- 51CTO技术论坛2012年度杰出版主评选盛典
- Windows Server 2012 版本及价格比较 Editions Overview.
- Visual Studio Express 2012 for Windows Phone
- 2. 计算机语言的发展过程
- 2012网站安全报告出炉 开源程序、电商网站成主要威胁对象
- 2012广电事件大盘点
- Windows Server 2012 RC 基于会话的桌面部署
- 安装SQL 2012群集
- Backup Exec 2012备份oracle
- Backup Exec 2012备份Lotus Domino