欧几里得算法

任务需求

  1. 在openEuler(推荐)或Ubuntu或Windows(不推荐)中完成下面任务
  2. 参考《密码工程》p112伪代码实现ExtendedGCD(int a, int b, int *k, int *u, int *v)算法(10’)
  3. 在测试代码中计算74模167的逆。(5‘)
  4. 提交代码和运行结果截图

运行结果

计算74模167的逆,经验算后符合结果

相关代码

#include<stdio.h>
#include<assert.h>
int main()
{
	unsigned int a,b;
    int s,t,m,gcd;
    int ExtendedGCD(unsigned int a,unsigned int b,int *k,int *u,int *v);
	printf("input two number:");
    while(scanf("%d%d",&a,&b)!=EOF)
    {
    	assert(a>=0);
    	assert(b>=0);
        gcd=ExtendedGCD(a,b,&s,&t,&m);
        printf("%d %d\n",s,t);
            printf("gcd = 1\n",b);
		printf("input two number:");
    }
    return 0;
}
int ExtendedGCD(unsigned int a,unsigned int b,int *k,int *u,int *v)//扩展欧几里得算法;
{
    if(b==0)
    {
        *k=1;
        *u=0;
        return a;
    }

    int i=ExtendedGCD(b,a%b,k,u,u);
    int t=*k;
    *k=*u;
    *u=t-a/b*(*u);
    return i;

}
 






posted @ 2022-06-09 15:12  爱冒险的丁丁  阅读(38)  评论(0编辑  收藏  举报