<五>Python的基础练习(循环、判断语句)

2024-01-07 18:56:13

1、输入俩个数,如果俩个数的差为奇数,则打印俩个数的差为奇数,如果俩个数的差为偶数,则打印俩个数的差为偶数。

nums = input("请输入二个数字,以逗号隔开:")
num_list = nums.split(",")
num1 = int(num_list[0])
num2 = int(num_list[1])
if (num1 - num2) % 2 == 0:
    print("num1:{}和num2:{}的差是偶数".format(num1, num2))
else:
    print("num1:{}和num2:{}的差是奇数".format(num1, num2))

注:input的返回值是str,可以通过格式转换将str转换成list,然后用索引分别获取俩个数再进行比较,就不用写俩个input了~

2、统计100以内,个位数是2并且能够被3整除的数。

for i in range(0, 101):
    if i % 3 == 0 and i % 10 == 2:
        print(i)

注:取个位数的方法,i%10

3、输入一个整整数,输出它是几位数

方法一:利用input获取的是个字符串,字符串的长度其实就是输入的数字的位数

num = input("请输入一个正整数:")
print("您输入的是%s位数" % len(num))

方法二:利用输入的数据除以10,得到的除数如果是大于1的,除几次就是几位数

num = int(input("请输入一个正整数:"))
if num == 0:
    count = 1
else:
    count = 0
while num > 1:
    num = num / 10
    count = count + 1

print("您输入的是%s位数" % count)

4、打印水仙花数,水仙花数是一个三位数,各个位数的立方和等于这个数本身

for i in range(100, 1000):
    num1 = i - ((i // 10) * 10)
    num2 = (i // 10) % 10
    num3 = i // 100
    if num1 ** 3 + num2 ** 3 + num3 ** 3 == i:
        print(i)

5、输出101~200中的素数,素数就是只能被1和它自己本身整除

for i in range(101, 201):
    for j in range(2, int(i**0.5)+1):
        if i % j == 0:
            break
    else:
        print(i)

注:for...else...语句,当循环里的break没有被执行时,就会执行else

6、求斐波那契数列中第n个数的值,n是正整数。第一个数和第二数是1,后面的数是前俩个数的和。

方法一:利用数组的概念

n = int(input("请输入要获取的斐波那契数列的个数n:"))
num1 = 1
num2 = 1
num_lists = [num1, num2]
count = 2
while True:
    num_lists.append(num_lists[-1] + num_lists[-2])
    count += 1
    if count == n:
        print("斐波那契数列的第%s个数是:" % n, num_lists[n-1])
        break

方法二:利用替换和循环

n = int(input("请输入要获取的斐波那契数列的个数n:"))
num1 = 1
num2 = 1
for i in range(0, n - 2):
    a = num1
    num1 = num2
    num2 = a + num2
print("斐波那契数列的前%d个数:" % n, num2)

7、"百马百担”问题:一匹大马能3担货,一匹中马能2担货,两匹小马能1担货,如果用一百匹马劲一百担货,问有大、中、小马各多少?

a1 = 3
a2 = 2
a3 = 0.5
for i in range(0, 100 // 3 + 1):
    for j in range(0, 100 // 2 + 1):
        if i * a1 + j * a2 + (100 - i - j) * a3 == 100:
            print(i, j, (100 - i - j))

文章来源:https://blog.csdn.net/xiaodaimu00/article/details/135377766
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。