2021-04-28循环分支结构

本文通过一系列编程示例介绍了如何使用for和while循环进行条件判断,包括输出3的倍数、个位或十位能被3整除的数,计算阶乘,统计个位为2且能被3整除的数的数量,判断素数,斐波那契数列,99乘法表,以及解决“百马百担”问题。这些例子涵盖了基础的编程概念和算法应用。
摘要由CSDN通过智能技术生成

循环分支结构(2021/04/28)

基础题

  1. 使用for和while循环输出 0~100内所有3的倍数。
# for循环计算
for num in range(0,100,3):
	print(num)
# while循环计算
num = 0
while num <= 100:
	if num % 3 == 0:
		print(num)
	num += 1

  1. 使用for和while循环输出100~200内个位数或者十位数能被3整除的数。
# for循环计算
for num in range(100, 200):
	if not(num % 10 % 3 != 0 and num // 10 % 10 % 3 != 0):
		print(num)
# while循环计算
num = 100
while num < 201:
    if not(num % 10 % 3 != 0 and num // 10 % 10 % 3 != 0):
        print(num)
    num += 1

进阶题

  1. 使用循环计算1*2*3*4*...*10的结果
cal = 1
for num in range(1,11):
    cal *= num
print(cal)

  1. 统计100以内个位数是2并且能够被3整除的数的个数。
count = 0
for sum in range(0, 101):
    if sum % 10 == 2 and sum % 3 == 0:
        count += 1
print(count)
  1. 输入任意一个正整数,求它是几位数?

  1. 打印出所有的水仙花数,所谓水仙花数是指一个三位数,其各位数字⽴方和等于该数本身。例如:153是一个水仙花数,因为 1³ + 5³ + 3³ 等于 153
for num in range(100, 999):
    gw = num % 10
    sw = num // 10 % 10
    bw = num // 100
    if num == gw**3 + sw**3 + bw**3:
        print(num)

挑战题

  1. 判断指定的数是否是素数(素数就是质数,即除了1和它本身以外不能被其他的数整除的数)
ipt_num = 89
count = 0
for num in range(2, ipt_num):
    if ipt_num % num == 0:
        count += 1
if count > 0:
    print(ipt_num,'不是素数')
else:
    print(ipt_num, '是素数')
  1. 求斐波那契数列列中第n个数的值:1,1,2,3,5,8,13,21,34… (这儿的n可以是任意正整数,可以通过输入来确定)
n = int(input('请输入一个正整数:'))
n_1 = 1
n_2 = 1
num = 0
for i in range(3, n+1):
    num = n_1 + n_2
    n_2 = n_1
    n_1 = num
print('第', n, '个数的值为:', num)
  1. 输出9*9口诀。 程序分析:分行与列考虑,共9行9列,i控制行,j控制列
for i in range(1, 10):
    for j in range(1, 10):
        cal = i * j
        print(i, '*', j, '=', cal, end = '|')
    print()
  1. 这是经典的"百马百担"问题,有一百匹马,驮一百担货,大马驮3担,中马驮2担,两只小马驮1担,问有大,中,小马各几匹?(可以直接使用穷举法)
for l in range(1, 100 // 3 +1):
    for m in range(1,100 // 2):
        s = 100 - l - m
        if l + m + s == 100 and 1 * 3 + m * 2 + s * 1/2 == 100:
            print('大马', l, '匹', '中马', m, '匹', '小马', s, '匹', )

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值