1.讀程序
numbers=1
for i in range(0,20):
numbers*=2
print(numbers)
numbers = 1
i = 0 ~ 19, 循環(huán)20次
i = 0 numers = 12 = 2 1次 21
i = 1 numbers = 22 2次 22
i = 2 numbers = 222 3次 23
numbers = 220
功能:求2的20次方
summation=0
num=1
while num<=100:
if (num%3==0 or num%7==0) and num%21!=0:
summation += 1
num+=1
print(summation)
求在1~100中能被3整數(shù)或者能夠被7整除,但是不同同時被3和7整除的數(shù)的個數(shù)
3.計算1-100之間能3整除的數(shù)的和
sum1 = 0
for x in range(1,101):
if x % 3 == 0:
sum1 += x
print(sum1)
sum1 = 0
for x in range(1,101):
if x % 3 != 0:
continue
sum1 += x
print(sum1)
4.求斐波那契數(shù)列中第n個數(shù)的值:1,1,2,3,5,8,13,21,34....
n = 1
n_1 = 1 # 前一個
n_2 = 1 # 前兩個
current = 1 # 當(dāng)前值
for x in range(3,n+1):
# 算出后一位
current = n_1 + n_2
# 往后移
n_2 = n_1
n_1 = current
5.判斷101-200之間有多少個素數(shù),并輸出所有素數(shù)。判斷素數(shù)的?法:??個數(shù)分別除2到sqrt(這個
數(shù)),如果能被整除,則表明此數(shù)不是素數(shù),反之是素數(shù)
什么是素數(shù)/質(zhì)數(shù): 除了1和它本身以外,不能被其他的數(shù)整除
# x取 101 ~ 200
for x in range(101,201):
count = 0
# y取 2 ~ x-1
for y in range(2, int(x**0.5)+1):
if x % y == 0:
count += 1
# print('%d不是素數(shù)' % (x))
break
if count == 0:
print('%d是素數(shù)' % (x))
6.打印出所有的?仙花數(shù),所謂?仙花數(shù)是指?個三位數(shù),其各位數(shù)字??和等于該數(shù)本身。例如:153是
?個?仙花數(shù),因為153 = 1^3 + 5^3 + 3^3
# 取出所有的三位數(shù)
for x in range(100,1000):
ge_wei = x%10
shi_wei = x//10%10
bai_wei = x//100
if x == ge_wei**3 + shi_wei**3 + bai_wei**3:
print('%d是水仙花數(shù)' % x)
8.給?個正整數(shù),要求:1、求它是?位數(shù) 2.逆序打印出各位數(shù)字
num = 16723 # 1672 167 16 1 0
# num2 = num
count = 0
while num != 0:
count += 1
print(num%10)
num //= 10
print(count)
# 方法二:
num = 16723
num_str = str(num)
print(len(num_str), num_str[::-1])