1 写程序计算10000以内有多少个素数。
def sushu(i):
if i == 1:
return False
for num in range(2, i):
if i % num == 0:
return False
else:
return True
if __name__ == '__main__':
su = []
for i in range(1, 10000):
if sushu(i):
su.append(i)
print(len(su))
2 写程序计算1至2021中有多少个数中包含数据7。(注意:如7,17,70等)
n = 2021
#包含7
while True:
res = []
for i in range(1,n+1):
if '7' in str(i):
res.append(i)
print(len(res))
break
print(res)
3 编写代码计算煤球数目。
一堆煤球,堆成三角棱锥形。第一层放1个,第二层放3个(排成3角形),
第3层放6个(排成3角形),第4层放10个(排成3角形),以此类推。
如果一共有90层,共有多少个煤球。
sum=0
count=0
for i in range(0,90):
i+=1
sum+=i
count+=sum
print(sum)
print(f"如果一共有{i}层,共有{count}个煤球。")
4 凑算式
A+B/C+(DEF)/(GHI)=10
算式中A-I代表1-9,不同的字母代表不同的数字。
6+8/3+952/714 是一种解法;
5+3/1+972/486 是一种解法。
就这个算式一共有多少种解法?请编写代码完成。
import itertools as it
count=0
x=[i for i in range(1,10)]
a=list(it.permutations(x,9))
for i in a:
if (i[0]+(i[1]/i[2])+((i[3]*100+i[4]*10+i[5])/(i[6]*100+i[7]*10+i[8])))==10:
count+=1
print(count)
5 有些数字的立方的末尾正好是该数字本身。比如1,4,5,6,9,24,25…
请你计算10000以内的数字中,符合各个特征的整数一共有多少个。
n=10000
res = 0
for i in range(1,n+1):
x = len(str(i))
y = pow(i,3)
if int(str(y)[-x:])== i:
res += 1
print(res)