c/c++实现模逆运算

c/c++实现模逆运算

最终结果:

在这里插入图片描述

实验原理:

在这里插入图片描述

代码实践:
#include <iostream>

using namespace std;

int main(int age, char * argv[]){
    int temp, q, t1, t2, t3;
    int a, b, swap=0;
    int x1, x2, x3, y1, y2, y3;
	int times = 0;
    cout << "Please input two integers: ";
	cin >> a >> b;
    if(a<b){
        swap = 1;
        temp = a;
        a = b;
        b = temp;
    }
    x1 = 1, x2 = 0, x3 = a;
    y1 = 0, y2 = 1, y3 = b;
    while(y3!=0){
        q = x3/y3;
        t1 = x1 - q * y1;
        t2 = x2 - q * y2;
        t3 = x3 - q * y3;
        x1 = y1;
        x2 = y2;
        x3 = y3;
        y1 = t1;
        y2 = t2;
        y3 = t3;
		times += 1;
        //输出并观察每一次的迭代
        cout << "第" << times << "次迭代:" << "t1:" << t1 << "   t2:" << t2 << "   t3:"<< t3 << endl;
    }
    if( x3 == 1){
        if( swap == 1){
			cout << "ninverse of: " << b << "  mod  " << a << " is: " << x2 <<endl; 
			cout << "ninverse of: " << a << "  mod  " << b << " is: " << x1 <<endl; 
        }
        else{
			cout << "ninverse of: " << a << "  mod  " << b << " is: " << x2 <<endl; 
			cout << "ninverse of: " << b << "  mod  " << a << " is: " << x1 <<endl; 
        }
    }
    else{
        cout << "no inverse" << endl;
    }
    return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值