快速入門(完整):Python例項100個(基於最新Python3.7版本)
Python3 100例
原題地址:
http://www.runoob.com/python/python-100-examples.html
git地址:
https://github.com/RichardFu123/Python100Cases
轉載請標註:
https://blog.csdn.net/weixin_41084236/article/details/81564963
原例為Python2.7版本
重寫過程中有不少是隨意發揮的
重寫執行版本:Python3.7
作者:Shawn
- 總的來說,並沒有什麼難度,全部摟了一遍也只花了不到2天時間,其中還有一半以上的時間是用來寫文件的。
- 用來練練手還是湊合的。
文章目錄
- Python3 100例
- 例項001:數字組合
- 例項002:“個稅計算”
- 例項003:完全平方數
- 例項004:這天第幾天
- 例項005:三數排序
- 例項006:斐波那契數列
- 例項007:copy
- 例項008:九九乘法表
- 例項009:暫停一秒輸出
- 例項010:給人看的時間
- 例項011:養兔子
- 例項012:100到200的素數
- 例項013:所有水仙花數
- 例項014:分解質因數
- 例項015:分數歸檔
- 例項016:輸出日期
- 例項017:字串構成
- 例項018:復讀機相加
- 例項019:完數
- 例項020:高空拋物
- 例項021:猴子偷桃
- 例項022:比賽對手
- 例項023:畫菱形
- 例項024:斐波那契數列II
- 例項025: 階乘求和
- 例項026:遞迴求階乘
- 例項027:遞迴輸出
- 例項028:遞迴求等差數列
- 例項029:反向輸出
- 例項030:迴文數
- 例項031:字母識詞
- 例項032:反向輸出II
- 例項033:列表轉字串
- 例項034:呼叫函式
- 例項035:設定輸出顏色
- 例項036:算素數
- 例項037:排序
- 例項038:矩陣對角線之和
- 例項039:有序列表插入元素
- 例項040:逆序列表
- 例項041:類的方法與變數
- 例項042:變數作用域
- 例項043:作用域、類的方法與變數
- 例項044:矩陣相加
- 例項045:求和
- 例項046:打破迴圈
- 例項047:函式交換變數
- 例項048:數字比大小
- 例項049:lambda
- 例項050:隨機數
- 例項051:按位與
- 例項052:按位或
- 例項053:按位異或
- 例項054:位取反、位移動
- 例項055:按位取反
- 例項056:畫圈
- 例項057:畫線
- 例項058:畫矩形
- 例項059:畫圖(醜)
- 例項060:字串長度
- 例項061:楊輝三角
- 例項062:查詢字串
- 例項063:畫橢圓
- 例項064:畫橢圓、矩形
- 例項065:畫組合圖形
- 例項066:三數排序
- 例項067:交換位置
- 例項068:旋轉數列
- 例項069:報數
- 例項070:字串長度II
- 例項071:輸入和輸出
- 例項072:建立連結串列
- 例項073:反向輸出連結串列
- 例項074:列表排序、連線
- 例項075:不知所云
- 例項076:做函式
- 例項077:遍歷列表
- 例項078:字典
- 例項079:字串排序
- 例項080:猴子分桃
- 例項081:求未知數
- 例項082:八進位制轉十進位制
- 例項083:製作奇數
- 例項084:連線字串
- 例項085:整除
- 例項086:連線字串II
- 例項087:訪問類成員
- 例項088:列印星號
- 例項089:解碼
- 例項090:列表詳解
- 例項091:time模組
- 例項092:time模組II
- 例項093:time模組III
- 例項094:time模組IV
- 例項095:轉換時間格式
- 例項096:計算復讀次數
- 例項097:磁碟寫入
- 例項098:磁碟寫入II
- 例項099:磁碟讀寫
- 例項100:列表轉字典
例項001:數字組合
題目 有四個數字:1、2、3、4,能組成多少個互不相同且無重複數字的三位數?各是多少?
程式分析 遍歷全部可能,把有重複的剃掉。
total=0
for i in range(1,5):
for j in range(1,5):
for k in range(1,5):
if ((i!=j)and(j!=k)and(k!=i)):
print(i,j,k)
total+=1
print(total)
簡便方法 用itertools中的permutations即可。
import itertools
sum2=0
a=[1,2,3,4]
for i in itertools.permutations(a,3):
print(i)
sum2+=1
print(sum2)
例項002:“個稅計算”
題目 企業發放的獎金根據利潤提成。利潤(I)低於或等於10萬元時,獎金可提10%;利潤高於10萬元,低於20萬元時,低於10萬元的部分按10%提成,高於10萬元的部分,可提成7.5%;20萬到40萬之間時,高於20萬元的部分,可提成5%;40萬到60萬之間時高於40萬元的部分,可提成3%;60萬到100萬之間時,高於60萬元的部分,可提成1.5%,高於100萬元時,超過100萬元的部分按1%提成,從鍵盤輸入當月利潤I,求應發放獎金總數?
程式分析 分割槽間計算即可。
profit=int(input('Show me the money: '))
bonus=0
thresholds=[100000,100000,200000,200000,400000]
rates=[0.1,0.075,0.05,0.03,0.015,0.01]
for i in range(len(thresholds)):
if profit<=thresholds[i]:
bonus+=profit*rates[i]
profit=0
break
else:
bonus+=thresholds[i]*rates[i]
profit-=thresholds[i]
bonus+=profit*rates[-1]
print(bonus)
例項003:完全平方數
題目 一個整數,它加上100後是一個完全平方數,再加上168又是一個完全平方數,請問該數是多少?
程式分析 因為168對於指數爆炸來說實在太小了,所以可以直接省略數學分析,用最樸素的方法來獲取上限:
n=0
while (n+1)**2-n*n<=168:
n+=1
print(n+1)
----------
85
思路是:最壞的結果是n的平方與(n+1)的平方剛好差168,由於是平方的關係,不可能存在比這更大的間隙。
至於判斷是否是完全平方數,最簡單的方法是:平方根的值小數為0即可。
結合起來:
n=0
while (n+1)**2-n*n<=168:
n+=1
for i in range((n+1)**2):
if i**0.5==int(i**0.5) and (i+168)**0.5==int((i+168)**0.5):
print(i-100)
例項004:這天第幾天
題目 輸入某年某月某日,判斷這一天是這一年的第幾天?
程式分析 特殊情況,閏年時需考慮二月多加一天:
def isLeapYear(y):
return (y%400==0 or (y%4==0 and y%100!=0))
DofM=[0,31,28,31,30,31,30,31,31,30,31,30]
res=0
year=int(input('Year:'))
month=int(input('Month:'))
day=int(input('day:'))
if isLeapYear(year):
DofM[2]+=1
for i in range(month):
res+=DofM[i]
print(res+day)
例項005:三數排序
題目 輸入三個整數x,y,z,請把這三個數由小到大輸出。
程式分析 練練手就隨便找個排序演算法實現一下,偷懶就直接調函式。
raw=[]
for i in range(3):
x=int(input('int%d: '%(i)))
raw.append(x)
for i in range(len(raw)):
for j in range(i,len(raw)):
if raw[i]>raw[j]:
raw[i],raw[j]=raw[j],raw[i]
print(raw)
raw2=[]
for i in range(3):
x=int(input('int%d: '%(i)))
raw2.append(x)
print(sorted(raw2))
例項006:斐波那契數列
題目 斐波那契數列。
程式分析 斐波那契數列(Fibonacci sequence),從1,1開始,後面每一項等於前面兩項之和。圖方便就遞迴實現,圖效能就用迴圈。
# 遞迴實現
def Fib(n):
return 1 if n<=2 else Fib(n-1)+Fib(n-2)
print(Fib(int(input())))
# 樸素實現
target=int(input())
res=0
a,b=1,1
for i in range(target-1):
a,b=b,a+b
print(a)
例項007:copy
題目 將一個列表的資料複製到另一個列表中。
程式分析 使用列表[:],拿不準可以呼叫copy模組。
import copy
a = [1,2,3,4,['a','b']]
b = a # 賦值
c = a[:] # 淺拷貝
d = copy.copy(a) # 淺拷貝
e = copy.deepcopy(a) # 深拷貝
a.append(5)
a[4].append('c')
print('a=',a)
print('b=',b)
print('c=',c)
print('d=',d)
print('e=',e)
============ RESTART: F:\PyWorkspace\Python100\100examples\007.py ============
a= [1, 2, 3, 4, ['a', 'b', 'c'], 5]
b= [1, 2, 3, 4, ['a', 'b', 'c'], 5]
c= [1, 2, 3, 4, ['a', 'b', 'c']]
d= [1, 2, 3, 4, ['a', 'b', 'c']]
e= [1, 2, 3, 4, ['a', 'b']]
例項008:九九乘法表
題目 輸出 9*9 乘法口訣表。
程式分析 分行與列考慮,共9行9列,i控制行,j控制列。
for i in range(1,10):
for j in range(1,i+1):
print('%d*%d=%2ld '%(i,j,i*j),end='')
print()
例項009:暫停一秒輸出
題目 暫停一秒輸出。
程式分析 使用 time 模組的 sleep() 函式。
import time
for i in range(4):
print(str(int(time.time()))[-2:])
time.sleep(1)
例項010:給人看的時間
題目 暫停一秒輸出,並格式化當前時間。
程式分析 同009.
import time
for i in range(4):
print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time())))
time.sleep(1)
例項011:養兔子
題目 有一對兔子,從出生後第3個月起每個月都生一對兔子,小兔子長到第三個月後每個月又生一對兔子,假如兔子都不死,問每個月的兔子總數為多少?
程式分析 我認為原文的解法有點扯,沒有考慮3個月成熟的問題,人家還是嬰兒怎麼生孩子?考慮到三個月成熟,可以構建四個資料,其中:一月兔每個月長大成為二月兔,二月兔變三月兔,三月兔變成年兔,成年兔(包括新成熟的三月兔)生等量的一月兔。
month=int(input('繁殖幾個月?: '))
month_1=1
month_2=0
month_3=0
month_elder=0
for i in range(month):
month_1,month_2,month_3,month_elder=month_elder+month_3,month_1,month_2,month_elder+month_3
print('第%d個月共'%(i+1),month_1+month_2+month_3+month_elder,'對兔子')
print('其中1月兔:',month_1)
print('其中2月兔:',month_2)
print('其中3月兔:',month_3)
print('其中成年兔:',month_elder)
例項012:100到200的素數
題目 判斷101-200之間有多少個素數,並輸出所有素數。
程式分析 判斷素數的方法:用一個數分別去除2到sqrt(這個數),如果能被整除,則表明此數不是素數,反之是素數。 用else可以進一步簡化程式碼.
import math
for i in range(100,200):
flag=0
for j in range(2,round(math.sqrt(i))+1):
if i%j==0:
flag=1
break
if flag:
continue
print(i)
print('\nSimplify the code with "else"\n')
for i in range(100,200):
for j in range(2,round(math.sqrt(i))+1):
if i%j==0:
break
else:
print(i)
例項013:所有水仙花數
題目 打印出所有的"水仙花數",所謂"水仙花數"是指一個三位數,其各位數字立方和等於該數本身。例如:153是一個"水仙花數",因為153=1的三次方+5的三次方+3的三次方。
程式分析 利用for迴圈控制100-999個數,每個數分解出個位,十位,百位。
for i in range(100,1000):
s=str(i)
one=int(s[-1])
ten=int(s[-2])
hun=int(s[-3])
if i == one**3+ten**3+hun**3:
print(i)
例項014:分解質因數
題目 將一個整數分解質因數。例如:輸入90,打印出90=233*5。
程式分析 根本不需要判斷是否是質數,從2開始向數本身遍歷,能整除的肯定是最小的質數。
target=int(input('輸入一個整數:'))
print(target,'= ',end='')
if target<0:
target=abs(target)
print('-1*',end='')
flag=0
if target<=1:
print(target)
flag=1
while True:
if flag:
break
for i in range(2,int(target+1)):
if target%i==0:
print("%d"%i,end='')
if target==i:
flag=1
break
print('*',end='')
target/=i
break
例項015:分數歸檔
題目 利用條件運算子的巢狀來完成此題:學習成績>=90分的同學用A表示,60-89分之間的用B表示,60分以下的用C表示。
程式分析 用條件判斷即可。
points=int(input('輸入分數:'))
if points>=90:
grade='A'
elif points<60:
grade='C'
else:
grade='B'
print(grade)
例項016:輸出日期
題目 輸出指定格式的日期。
程式分析 使用 datetime 模組。
import datetime
print(datetime.date.today())
print(datetime.date(2333,2,3))
print(datetime.date.today().strftime('%d/%m/%Y'))
day=datetime.date(1111,2,3)
day=day.replace(year=day.year+22)
print(day)
例項017:字串構成
題目 輸入一行字元,分別統計出其中英文字母、空格、數字和其它字元的個數。
程式分析 利用 while 或 for 語句,條件為輸入的字元不為 ‘\n’。
string=input("輸入字串:")
alp=0
num=0
spa=0
oth=0
for i in range(len(string)):
if string[i].isspace():
spa+=1
elif string[i].isdigit():
num+=1
elif string[i].isalpha():
alp+=1
else:
oth+=1
print