最小python
⑴ python求最大公约数和最小公倍数
python求最大公约数和最小公倍数
定义一个函数
def hcf(x, y):
该函数返回两个数的最大公约数
# 获取最小值
if x > y:
smaller = y
else:
smaller = x
for i in range(1,smaller + 1):
if((x % i == 0) and (y % i == 0)):
hcf = i
return hcf
# 用户输入两个数字
num1 = int(input("输入第一个数字: "))
num2 = int(input("输入第二个数字: "))
print( num1,"和", num2,"的最大公约数为", hcf(num1, num2))
求两个数的最小公倍数的算法有很多种,效率最高的一种是先计算出它们的最大公约数。
采用辗转相除法,可以求出两个正整数的最大公约数。先保存a和b的数值的副本,求出a÷b的余数,如果不等于零,就令a=b,b等于这一次的余数。
重复做上述的除法零,直到余数为0的时候,B的值就是一开始两个数的最大公约数。这时初始的两数乘积除以最大公约数就是两个数的最小公倍数。
⑵ python 求n个数最大值 最小值
我可以使用Python内置的max和min函数来完成这个任务,或者对输入的数进行排序后取第一个和最后一个元素。以下是两种可能的函数实现:
# 方法一:使用max和min函数def max_min(nums): # 判断输入是否为空
if not nums: return None, None
# 使用max和min函数求孝衫斗最塌厅大值和最巧磨小值
max_num = max(nums)
min_num = min(nums) return max_num, min_num# 方法二:使用排序后取首尾元素def max_min(nums): # 判断输入是否为空
if not nums: return None, None
# 对输入的数进行排序
nums.sort() # 取第一个和最后一个元素作为最大值和最小值
max_num = nums[-1]
min_num = nums[0] return max_num, min_num# 测试函数n = int(input("请输入要输入的数的个数:\n"))
nums = []for i in range(n):
num = int(input(f"请输入第{i+1}个数:\n"))
nums.append(num)
max_num, min_num = max_min(nums)print(f"这些数中的最大值是{max_num},最小值是{min_num}")
