个人主页: Aileen_0v0
热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法
个人格言:“没有罗马,那就自己创造罗马~”
Stop struggling, life is stopped.
文章目录
-
- `水仙花数`
- `输出所有素数`
- `输出2000年至2020年每一天的日期`
水仙花数
写法1:正向思维,把每一个位的数字都拆出来,按照题目条件写代码。 |
for i in range (100,1000):
A = i // 100
B = (i % 100) // 10
C = (i % 10)
if A**3 + B**3 + C**3 == i:
print(f"{i}是水仙数。")
写法2:逆向思维,将每一位的数字都遍历一遍,就像是排列组合一样,然后再将他们组合后的数字按照条件进行比较。 |
for A in range(1,10):
for B in range(1,10):
for C in range(0,10):
left = A**3 + B**3 + C**3
right = A * 100 + B * 10 + C
if left == right:
print(left)
输出所有素数
- 求[L,R]中所有的素数
- 素数的定义: x是素数,当且仅当X只能被1和本身整除
- 如果x被[2,X-1]中任意一个数字整险则x不是素数
l = int(input())
R = int(input())
for i in range(l,R+1):
ok = True
for j in range(2,i):
if i % j == 0:
ok = False
break
if ok == True and i != 1:
print(i)
Created with Raphaël 2.3.0 tip:只要有一个条件不满足就不成立的可以用标记法。
输出2000年至2020年每一天的日期
count = 0
T = 0
for year in range (2000,2021):
for month in range (1,13):
if month == 2:
if year % 400 == 0 or (year % 100 != 0 and year % 4 == 0):
last = 29
T += 1
else:
last = 28
elif month == 4 or month == 6 or month == 9 or month == 12:
last = 30
else:
last = 31
for day in range(1,last + 1):
print(year, month, day)
count += 1
print(count,365 * 21)
print(T)