北京理工大学python慕课
2019.05.13
第四章 程序的分支结构练习
练习一:
四维玫瑰数
四位玫瑰数是4位数的自幂数。自幂数是指一个 n 位数,它的每个位上的数字的 n 次幂之和等于它本身。
例如:当n为3时,有1^3 + 5^3 + 3^3 = 153,153即是n为3时的一个自幂数,3位数的自幂数被称为水仙花数。
请输出所有4位数的四位玫瑰数,按照从小到大顺序,每个数字一行。
代码:
for i in range(1000,10000):
a=i//1000
b=(i-a*1000)//100
c=(i-a*1000-b*100)//10
d=i-a*1000-b*100-c*10
M=pow(a,4)+pow(b,4)+pow(c,4)+pow(d,4)
if M==i:
print(i)
else:
continue
总结:
- range(a,b)是从a到b-1的范围;
- 需要灵活运用continue&break。
练习二:
输出1-100之间的所有素数
count=0
for i in range(2,101):
a=0 #标记变量,如果它在循环的最后还是为0,那么该数为素数
for j in range(2,i):
c=i%j
if c==0:
a=1 #(重要)如果取余之后的数为0,那么该数肯定不为素数,令标记变量为1
if a==0:
print(i)
求1-100内所有素数之和
count=0 #计数变量,注意该类变量的使用
for i in range(2,101):
a=0
for j in range(2,i):
c=i%j
if c==0:
a=1
if a==0:
count=count+i
print(i)
print(count)
总结:该题编程跌跌撞撞,刚接触编程不久,不能灵活运用各种方法,编程思维有待加强。需要多加练习!