Java实现算法导论中求解模线性方程解(基于最大公约数欧几里得扩展算法)

153 篇文章 2 订阅
60 篇文章 48 订阅

基于最大公约数欧几里得扩展算法求解算法导论中模线性方程解。具体要结合算法导论中的有关数论算法章节理解,具体代码如下:

package cn.ansj;

/*
  假设方程ax=b(mod n)有解,且x0是方程的任意一个解,
  则该方程对模n恰有d个不同的解(d=gcd(a,n)),分别为:xi=x0+i*(n/d) mod n 。
 */
public class ModularLinearEquation {
	static int x,y;
	public static int extend_gcd(int a, int b){
		if (b == 0){
	        x = 1;
	        y = 0;
	        return a;
	    }
	    int re = extend_gcd(b, a % b);
	    int tmp = x;
	    x = y;
	    y = tmp - a / b * y;
	    return re;
	}
	
	public static void main(String args[]) { 
		int a=777;
		int b=66;
		int n=6;
		int d=extend_gcd(a,n);
		System.out.println("最大公约数d="+d+" And x="+x+" And y="+y);
		if(b%d!=0) System.out.println("no solution");
		else{
			int x0=x*(b/d)%n;
			System.out.println("x0="+x0);
			for(int i=1;i<d;i++)
				System.out.println("solution:"+(x0+i*(n/d))%n);
		}		  
	}
}

执行结果:

最大公约数d=3 And x=1 And y=-129
x0=4
solution:0
solution:2


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值