#include<iostream> using namespace std; //不推荐用goto,当然用它更快 //辗转相除法求两数的最大公约数 int gcd(long int a,long int b){ int x=a<b?a:b; //获得较小者,用来做循环的约束值 ;i<x;x++){ //循环 if(a>b){ int r=a%b;//取余数 ){//能否整除判断 return b;//可以便输出 }else{//否则进行下一轮的算法 a=b,b=r; } }…
辗转相除法,又称欧几里得算法.两个正整数a和b(a>b),它们的最大公约数等于余数c和较小的数b之间的最大公约数.最小公倍数=两数之积/最大公约数 #include <stdio.h> int get1(int a, int b) { if (a < b) { int c = a; a = b; b = c; } while (a%b != 0) { b = a%b; a = b; } return b; } int get2(int a,int b) { return a*b /…
def myfun(): num1 = int(input('输入num1')) num2 = int(input('输入num2')) list1=[] for i in range(1, max(num1, num2)): if num1 % i == 0 and num2 % i == 0: list1.append(i) print('最大公约数:',max(list1) ) print('最小公倍数:',num1 * num2 // max(list1))myfun()…