设两数为a、b(a>b),求a和b最大公约数(a,b)的步骤如下:用a除以b,得a÷b=q......r1(0≤r1)。若r1=0,则(a,b)=b;若r1≠0,则再用b除以r1,得b÷r1=q......r2 (0≤r2).若r2=0,则(a,b)=r1,若r2≠0,则继续用r1除以r2,……如此下去,直到能整除为止。其最后一个为被除数的余数的除数即为(a, b)。
例如:a=25,b=15,a/b=1......10,b/10=1......5,10/5=2.......0,最后一个为被除数余数的除数就是5,5就是所求最大公约数。
那么最后一次运算的除数就是两数的最大公约数,那么他们的最小公倍数就是两数的积除以他们的最大公约数;
Scanner sc=new Scanner(System.in);
int a=sc.nextInt();
int b=sc.nextInt();
if(a<b){
b=a+b;
a=b-a;
b=b-a;
}else if(a==b){
System.out.print("最大公约数:"+a);
System.out.print("最小公倍数:”+a);
}
while(a%b!=0){
a=b;
b=a%;
System.out.print("最大公约数:"+b);
System.out.print("最小公倍数:”+b);}