python第四期习题练习

学习内容:

习题一:定义函数 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()

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值