拓展欧几里德求逆元模板(Java版)

Java没有传引用这种东西,long的包装类又是final的,所以只能用数组来代替一下

拓展欧几里德这东西真实难懂,逆元这东西也是难懂

import java.io.*;
import java.util.Scanner;
import java.util.StringTokenizer;

public class Main {
   

    static long n,b;
    static final int MOD=9973;

    static long exgcd(long a,long b,long[] x,long[] y){
   
        if(b==0){
   
            x[0]= 1L;
            y[0]= 0L;
            return a;
        }
        long d=exgcd(b,a%b,x,y);
        long tmp=x[0];
        x[0]=y[0];
        y[0]=tmp-a/b*y[0];
        return d;
    }

    static long inv(long a,long m){
   
        long[] x={
   0};
        long[] y={
   0};
        long d=exgcd(a,m,x,y);
        if(d==1){
   
            return (x[0]%m+m)%m;
        }
        return -1;
    }
    public static void main(String[] args) {
   
        Scanner cin=new Scanner(System.in);
        int t=cin.nextInt();
        while(t-->0){
   
            n=cin.nextLong();
            b=cin.nextLong();
            long c=inv(b,MOD);
            System.out.println(n*c%MOD);
        }
    }
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-16 14:00
白火同学:其实你可以了解一下HR在Boss聊天的机制,想赢牌的前提是先会玩牌。 如果HR长时间没有理你,有可能是因为你的消息被其他应聘者的消息给挤到下面了,HR从上到下有可能只看个三四百个人就要到理想数量的简历了,而你恰好没有被看到,时间一长,你的消息在越来越下面。这种情况就需要你自己活跃一下,把消息提上去。 也可能是HR招的合适的人选了,但会一直挂着岗位,为了省重新开招聘岗位的钱,方便后面随时修改招聘要求。 当然也可能是HR吃饱了没事耍你玩,要了你的简历又不看,就看你自己怎么理解了。
点赞 评论 收藏
分享
06-17 21:57
门头沟学院 Java
白友:噗嗤,我发现有些人事就爱发这些,明明已读不回就行了,就是要恶心人
点赞 评论 收藏
分享
炫哥_:为什么都读硕士了?项目还是网上的项目(真心发问)
最后再改一次简历
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务