扩展Stein算法计算乘法逆元(C语言版)

本文介绍了如何扩展Stein算法来计算乘法逆元,特别是针对C语言的实现。通过算法流程图和具体的C语言代码,详细展示了求解B在模A上的逆元的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

扩展Stein算法一般用来计算两个数字的最大公约数,其算法思想如下:

 

用Stein算最大公约数的算法在网上有很多,就不列出了。

 

现给出扩展Stein算法来求乘法逆元的方法:

算法流程图如下:(求B在模A上的逆)

C语言代码如下:

//交换算法
void swap(int *a, int *b) {
	*a ^= *b;       //a=a^b
	*b ^= *a;      //b=b^(a^b)=b^a^b=b^b^a=0^a=a
	*a ^= *b;     //a=(a^b)^a=a^b^a=a^a^b=0^b=b
}

//计算的是B在模A上的逆 B^(-1)modA
int mod_reverse_Stein(int b, int a)
{
	int A = a;
	int B = b;
	int x =
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值