学习内容:
习题一:定义函数 max(x, y, z),返回三个整数的输入的最大值
def max_n(a,b,c):
if(a>b):
max=a
else:
max=b
if(max>c):
max=max
else:
max=c
print("最大值是:",max)
x=int(input('请输入第一个值:'))
y=int(input('请输入第二个值:'))
z=int(input('请输入第三个值:'))
max_n(x,y,z)
习题二:定义函数 count( ) ,统计⼀个字符串中大写字母、小写字母、数字的个数,并以字典为结果返回给调用者。
str1 = input("请输入要一个字符串:")
def count(str1):
Capital = little = digit =0
for i in str1:
if i.islower():
Capital += 1
elif i.isupper():
little += 1
else:
digit += 1
return ('A-Z', Capital),('a-z',little),('0-9',digit)
print (count(str1))
习题三:编写程序判断点是否在正方形内。有一个正方形,四个角的坐标(x,y)分别是(1,-1),(1,1),(-1,-1),(-1,1),x是横轴,y是纵轴。写一个程序,判断一个给定的点是否在这个正方形内(包括正方形边界)。如果点在正方形内,则输出yes,否则输出no。(点的坐标(m,n)由外部输入)
point = input("请输入一个点坐标:").split() # 输入一行,包括两个整数m、n,以一个空格分开,表示坐标(m,n)。
m = float(point[0])
n = float(point[1])
if -1 <= m <= 1 and -1<= n <= 1:
print("yes")
else:
print("no")
习题四:编写一个函数,计算输出三角形的面积。要求外部输入三边的边长,其为浮点数类型。已知三角的面积公式为:A=(s*(s-a)(s-b)(s-c)) ** 0.5,其中a,b,c为三角形三边的边长,并且s=(a+b+c)/2。
a = float(input('输入三角形第一边长: '))
b = float(input('输入三角形第二边长: '))
c = float(input('输入三角形第三边长: '))
s = (a + b + c) / 2
A = (s*(s-a)*(s-b)*(s-c)) ** 0.5
print(f'三角形面积为:{A}')
习题五:编写程序模拟轮盘抽奖游戏:轮盘分为三部分: 一等奖, 二等奖和三等奖;轮盘转的时候是随机的。如果范围在[0,0.08)之间,代表一等奖,如果范围在[0.08,0.3)之间,代表2等奖,如果范围在[0.3, 1.0)之间,代表3等奖。
import random
rewardpp = {
'一等奖':(0,0.08),
'二等奖':(0.08,0.3),
'三等奖':(0.3, 1)
}
def rewardFun(): #用户的得奖等级
number = random.random()
for k,v in rewardpp.items():
if v[0] <= number < v[1]:
return k
resultDict = {} #定义一个空的字典,存放奖项对应出现的次数
for i in range(1000): #该循环进行奖项次数的计算,并且存入新的字典里
res = rewardFun()
if res not in resultDict:
resultDict[res] = 1
else:
resultDict[res] += 1
for k,v in resultDict.items():
print(k,':',v)
习题六:定义一个函数is_prime(n),判断输入的n是不是素数,是的话返回True,否则返回False。通过键盘输入两个整数X和Y,调用此函数输出两数范围之内素数的个数(包括X和Y)。
import math
def is_prime(n):
m = int(math.sqrt(n)+1)
for i in range(2,m):
if n%i==0:
return False
break
else:
return True
def main():
n,m =eval(input("请输入两个数,来求这两个数之间素数的个数,逗号作为分隔符:"))
count = 0
for i in range (n,m+1):
if is_prime(i) == True:
count=count+1
print(count)
main()
习题七:已知一个数如果从左往右读和从右往左读数字是相同的,则称这个数是回文数,如121,1221,15651都是回文数。现在请写出一个函数h(n),判断n是否为回文数,是的话返回True,否则返回False。利用上面的判断素数函数,找出所有既是回文数又是素数的3位十进制数。
n = str(input("请输入一个数字:"))
def h(n):
return n == n[::-1]
print (h(n))
import math
def is_prime(n):
m = int(math.sqrt(n)+1)
for i in range(2,m):
if n%i==0:
return False
break
else:
return True
def h(n):
a = n//100
b = n%10
if a == b:
return True
else:
return False
def main():
print("既是素数又是回文数的3位十进制数:")
for i in range (100,1000):
if is_prime(i) == True:
if h(i) == True:
print(i)
main()