# 作者:JohnRothan
# 时间:2022-5-3
# 题目信息:阶乘
def fact(num): #阶乘函数
if num<0:
print("非法输入!")
exit()
elif num==0:
result=1
else:
result=num*fact(num-1)
return(result)
num=int(input("请输入整数num(num>=0):"))
print(num,"! = ",fact(num)) #调用阶乘函数
测试结果:
请输入整数num(num>=0):3
3 ! = 6
请输入整数num(num>=0):0
0 ! = 1
请输入整数num(num>=0):-4
非法输入!
# 作者:JohnRothan
# 时间:2022-5-3
# 题目信息:Fibonacci前20项输出
#递归实现
def fib(num):
if num <= 2: return(1)
else:
return(fib(num-1)+fab(num-2))
num=20
for i in range(1,num+1):
print(format(fab(i),">5"),end=' ')
if(i % 10==0):print("\n")
测试结果:
1 1 2 3 5 8 13 21 34 55
89 144 233 377 610 987 1597 2584 4181 6765
# 作者:JohnRothan
# 时间:2022-5-3
# 题目信息:Fibonacci前20项输出
# 非递归实现
def fib(n):
result = [0,1]
if n <= 1:
return result[n]
for i in range(2,n+1):
result.append(result[i-1]+result[i-2])
return result[n]
num=20
for i in range(1,num+1):
print(format(fib(i),">5"),end=' ')
if(i % 10==0):print("\n")
测试结果:
1 1 2 3 5 8 13 21 34 55
89 144 233 377 610 987 1597 2584 4181 6765
# 作者:JohnRothan
# 时间:2022-5-3
# 题目信息:最小值比较输出
def min_n(a, b, *c):
min = a
if min > b:
min = b
for n in c:
if min > n:
min = n
return min
#测试代码
print("最小值为",min_n(8, 2))
print("最小值为",min_n(16, 1, 7, 4, 15))
测试结果:
最小值为 2
最小值为 1
# 作者:JohnRothan
# 时间:2022-5-3
# 题目信息:求序列最大值、最小值、元素个数#求序列类型的最大值和最小值
def arrInfo(s):
max = s[0]
min = s[0]
for i in range( 0, len(s)):
if max<s[i]:
max = s[i]
if min>s[i]:
min = s[i]
return max,min,len(s)
#测试代码
list1=[1,51,-3,23,0,10,-13]
x1,y1,z1 = arrInfo(list1)
print("list=", list1)
print("最大值=",x1, ",最小值=", y1, ",元素个数=", z1)
list2=["USA","RU","IN","EN"]
x2,y2,z2 = arrInfo(list2)
print("list=", list2)
print("最大值=",x2, ",最小值=", y2, ",元素个数=", z2)
list4=(1,51,-3,23,0,10,-13)
x4,y4,z4 = arrInfo(list4)
print("list=", list4)
print("最大值=",x4, ",最小值=", y4, ",元素个数=", z4)
测试结果:
list= [1, 51, -3, 23, 0, 10, -13]
最大值= 51 ,最小值= -13 ,元素个数= 7
list= ['USA', 'RU', 'IN', 'EN']
最大值= USA ,最小值= EN ,元素个数= 4
list= (1, 51, -3, 23, 0, 10, -13)
最大值= 51 ,最小值= -13 ,元素个数= 7