Python100道練習題,建議收藏




點擊上方藍字關注我們





點擊上方“印象python”,選擇“星標”公衆號

重磅乾貨,第一時間送達!

‍來源丨大學計算機基礎
鏈接丨https://github.com/RichardFu123/Python100Cases
目錄
實例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=0for 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+=1print(total)


簡便方法 用itertools中的permutations即可。


import itertoolssum2=0a=[1,2,3,4]for i in itertools.permutations(a,3):    print(i)    sum2+=1print(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=0thresholds=[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=0while (n+1)**2-n*n<=168:    n+=1
print(n+1)


思路是:最壞的結果是n的平方與(n+1)的平方剛好差168,由於是平方的關係,不可能存在比這更大的間隙。

至於判斷是否是完全平方數,最簡單的方法是:平方根的值小數爲0即可。

結合起來:


n=0while (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=0year=int(input('Year:'))month=int(input('Month:'))day=int(input('day:'))if isLeapYear(year):    DofM[2]+=1for 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=0a,b=1,1for i in range(target-1): a,b=b,a+bprint(a)


實例007:copy

題目 將一個列表的數據複製到另一個列表中。


程序分析 使用列表[:],拿不準可以調用copy模塊。


import copya = [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 timefor 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=1month_2=0month_3=0month_elder=0for 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 mathfor 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=0if 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 datetimeprint(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=0num=0spa=0oth=0for 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+=1print('space: ',spa)print('digit: ',num)print('alpha: ',alp)print('other: ',oth)


實例018:復讀機相加

題目 求s=a+aa+aaa+aaaa+aa…a的值,其中a是一個數字。例如2+22+222+2222+22222(此時共有5個數相加),幾個數相加由鍵盤控制。


程序分析 用字符串解決。


a=input('被加數字:')n=int(input('加幾次?:'))res=0for i in range(n):    res+=int(a)    a+=a[0]print('結果是:',res)


實例019:完數

題目 一個數如果恰好等於它的因子之和,這個數就稱爲"完數"。例如6=1+2+3.編程找出1000以內的所有完數。


程序分析 將每一對因子加進集合,在這個過程中已經自動去重。最後的結果要求不計算其本身。


def factor(num):    target=int(num)    res=set()    for i in range(1,num):        if num%i==0:            res.add(i)            res.add(num/i)    return res
for i in range(2,1001): if i==sum(factor(i))-i: print(i)


實例020:高空拋物

題目 一球從100米高度自由落下,每次落地後反跳回原高度的一半;再落下,求它在第10次落地時,共經過多少米?第10次反彈多高?


程序分析 無



high=200.total=100for i in range(10): high/=2 total+=high print(high/2)print('總長:',total)


實例021:猴子偷桃

題目 猴子喫桃問題:猴子第一天摘下若干個桃子,當即吃了一半,還不癮,又多吃了一個第二天早上又將剩下的桃子喫掉一半,又多吃了一個。以後每天早上都吃了前一天剩下的一半零一個。到第10天早上想再喫時,見只剩下一個桃子了。求第一天共摘了多少。


程序分析 按規則反向推斷:猴子有一個桃子,他偷來一個桃子,覺得不夠又偷來了與手上等量的桃子,一共偷了9天。


peach=1for i in range(9):    peach=(peach+1)*2print(peach)


實例022:比賽對手

題目 兩個乒乓球隊進行比賽,各出三人。甲隊爲a,b,c三人,乙隊爲x,y,z三人。已抽籤決定比賽名單。有人向隊員打聽比賽的名單。a說他不和x比,c說他不和x,z比,請編程序找出三隊賽手的名單。


程序分析 找到條件下不重複的三個對手即可。


a=set(['x','y','z'])b=set(['x','y','z'])c=set(['x','y','z'])c-=set(('x','y'))a-=set('x')for i in a:    for j in b:        for k in c:            if len(set((i,j,k)))==3:                print('a:%s,b:%s,c:%s'%(i,j,k))


實例023:畫菱形

題目 打印出如下圖案(菱形):


    *

   ***

  *****

 *******

  *****

   ***

    *


程序分析 遞歸調用即可。


def draw(num):    a="*"*(2*(4-num)+1)    print(a.center(9,' '))    if num!=1:        draw(num-1)        print(a.center(9,' '))draw(4)


實例024:斐波那契數列II

題目 有一分數序列:2/1,3/2,5/3,8/5,13/8,21/13…求出這個數列的前20項之和。


程序分析 就是斐波那契數列的後一項除以前一項。


a = 2.0b = 1.0s = 0for n in range(1,21):    s += a / b    a,b = a + b,aprint (s)


實例025:階乘求和

題目 求1+2!+3!+…+20!的和。


程序分析 1+2!+3!+…+20!=1+2(1+3(1+4(…20(1))))


res=1for i in range(20,1,-1):    res=i*res+1print(res)


實例026:遞歸求階乘

題目 利用遞歸方法求5!。


程序分析 遞歸調用即可。


def factorial(n):    return n*factorial(n-1) if n>1 else 1print(factorial(5))


實例027:遞歸輸出

題目 利用遞歸函數調用方式,將所輸入的5個字符,以相反順序打印出來。


程序分析 遞歸真是蠢方法。


def rec(string):    if len(string)!=1:        rec(string[1:])    print(string[0],end='')
rec(input('string here:'))


實例028:遞歸求等差數列

題目 有5個人坐在一起,問第五個人多少歲?他說比第4個人大2歲。問第4個人歲數,他說比第3個人大2歲。問第三個人,又說比第2人大兩歲。問第2個人,說比第一個人大兩歲。最後問第一個人,他說是10歲。請問第五個人多大?


程序分析 就一等差數列。


def age(n):    if n==1:        return 10    return 2+age(n-1)print(age(5))


實例029:反向輸出

題目 給一個不多於5位的正整數,要求:一、求它是幾位數,二、逆序打印出各位數字。


程序分析 學會分解出每一位數,用字符串的方法總是比較省事。


n=int(input('輸入一個正整數:'))n=str(n)print('%d位數'%len(n))print(n[::-1])


實例030:迴文數

題目 一個5位數,判斷它是不是迴文數。即12321是迴文數,個位與萬位相同,十位與千位相同。


程序分析 用字符串比較方便,就算輸入的不是數字都ok。


n=input("隨便你輸入啥啦:")a=0b=len(n)-1flag=Truewhile a<b:    if n[a]!=n[b]:        print('不是迴文串')        flag=False        break    a,b=a+1,b-1if flag:    print('是迴文串')


實例031:字母識詞

題目 請輸入星期幾的第一個字母來判斷一下是星期幾,如果第一個字母一樣,則繼續判斷第二個字母。


程序分析 這裏用字典的形式直接將對照關係存好。


weekT={'h':'thursday',       'u':'tuesday'}weekS={'a':'saturday',       'u':'sunday'}week={'t':weekT,      's':weekS,      'm':'monday',      'w':'wensday',      'f':'friday'}a=week[str(input('請輸入第一位字母:')).lower()]if a==weekT or a==weekS:    print(a[str(input('請輸入第二位字母:')).lower()])else:    print(a)


實例032:反向輸出II

題目 按相反的順序輸出列表的值。


程序分析 無。


a = ['one', 'two', 'three']print(a[::-1])


實例033:列表轉字符串

題目 按逗號分隔列表。


程序分析 無。


L = [1,2,3,4,5]print(','.join(str(n) for n in L))


實例034:調用函數

題目 練習函數調用。


程序分析 無。


def hello():    print('Hello World!')def helloAgain():    for i in range(2):        hello()
if __name__=='__main__': helloAgain()


實例035:設置輸出顏色

題目 文本顏色設置。


程序分析 無。

class bcolors:    HEADER = '\033[95m'    OKBLUE = '\033[94m'    OKGREEN = '\033[92m'    WARNING = '\033[93m'    FAIL = '\033[91m'    ENDC = '\033[0m'    BOLD = '\033[1m'    UNDERLINE = '\033[4m'print(bcolors.WARNING + "警告的顏色字體?" + bcolors.ENDC)


實例036:算素數

題目 求100之內的素數。


程序分析 用else執行for循環的獎勵代碼(如果for是正常完結,非break)。


lo=int(input('下限:'))hi=int(input('上限:'))for i in range(lo,hi+1):    if i > 1:        for j in range(2,i):            if (i % j) == 0:                break        else:            print(i)


實例037:排序

題目 對10個數進行排序。


程序分析 同實例005。


raw=[]for i in range(10):    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)


實例038:矩陣對角線之和

題目 求一個3*3矩陣主對角線元素之和。


程序分析 無。


mat=[[1,2,3],     [3,4,5],     [4,5,6]    ]res=0for i in range(len(mat)):    res+=mat[i][i]print(res)


實例039:有序列表插入元素

題目 有一個已經排好序的數組。現輸入一個數,要求按原來的規律將它插入數組中。


程序分析 首先判斷此數是否大於最後一個數,然後再考慮插入中間的數的情況,插入後此元素之後的數,依次後移一個位置。



lis=[1,10,100,1000,10000,100000]n=int(input('insert a number: '))lis.append(n)for i in range(len(lis)-1): if lis[i]>=n: for j in range(i,len(lis)): lis[j],lis[-1]=lis[-1],lis[j] breakprint(lis)


實例040:逆序列表

題目 將一個數組逆序輸出。


程序分析 依次交換位置,或者直接調用reverse方法。


lis=[1,10,100,1000,10000,100000]for i in range(int(len(lis)/2)):    lis[i],lis[len(lis)-1-i]=lis[len(lis)-1-i],lis[i]print('第一種實現:')print(lis)

lis=[1,10,100,1000,10000,100000]print('第二種實現:')lis.reverse()print(lis)


實例041:類的方法與變量

題目 模仿靜態變量的用法。


程序分析 構造類,瞭解類的方法與變量。


def dummy():    i=0    print(i)    i+=1
class cls: i=0 def dummy(self): print(self.i) self.i+=1
a=cls()for i in range(50): dummy() a.dummy()


實例042:變量作用域

題目 學習使用auto定義變量的用法。


程序分析 python中的變量作用域。


i=0n=0def dummy():    i=0    print(i)    i+=1def dummy2():    global n    print(n)    n+=1print('函數內部的同名變量')for j in range(20):    print(i)    dummy()    i+=1print('global聲明同名變量')for k in range(20):    print(n)    dummy2()    n+=10


實例043:作用域、類的方法與變量

題目 模仿靜態變量(static)另一案例。


程序分析 綜合實例041和實例042。


class dummy:    num=1    def Num(self):        print('class dummy num:',self.num)        print('global num: ',num)        self.num+=1
n=dummy()num=1for i in range(5): num*=10 n.Num()


實例044:矩陣相加

題目 計算兩個矩陣相加。


程序分析 創建一個新的矩陣,使用 for 迭代並取出 X 和 Y 矩陣中對應位置的值,相加後放到新矩陣的對應位置中。


X = [[12,7,3],    [4 ,5,6],    [7 ,8,9]]
Y = [[5,8,1], [6,7,3], [4,5,9]]
res=[[0,0,0], [0,0,0], [0,0,0]]for i in range(len(res)): for j in range(len(res[0])): res[i][j]=X[i][j]+Y[i][j]print(res)


實例045:求和

題目 統計 1 到 100 之和。


程序分析 無


res=0for i in range(1,101):    res+=iprint(res)


實例046:打破循環

題目 求輸入數字的平方,如果平方運算後小於 50 則退出。


程序分析 無


while True:    try:        n=float(input('輸入一個數字:'))    except:        print('輸入錯誤')        continue    dn=n**2    print('其平方爲:',dn)    if dn<50:        print('平方小於50,退出')        break


實例047:函數交換變量

題目 兩個變量值用函數互換。


程序分析 無


def exc(a,b):    return (b,a)a=0b=10a,b=exc(a,b)print(a,b)


實例048:數字比大小

題目 數字比較。


程序分析 無


a=int(input('a='))b=int(input('b='))if a<b:    print('a<b')elif a>b:    print('a>b')else:    print('a=b')


實例049:lambda

題目 使用lambda來創建匿名函數。


程序分析 無


Max=lambda x,y:x*(x>=y)+y*(y>x)Min=lambda x,y:x*(x<=y)+y*(y<x)
a=int(input('1:'))b=int(input('2:'))
print(Max(a,b))print(Min(a,b))


實例050:隨機數

題目 輸出一個隨機數。


程序分析 使用 random 模塊。


import randomprint(random.uniform(10,20))


實例051:按位與

題目 學習使用按位與 & 。


程序分析 0&0=0; 0&1=0; 1&0=0; 1&1=1。


a=0o77print(a)b=a&3print(b)b=b&7print(b)


實例052:按位或

題目 學習使用按位或 | 。


程序分析 0|0=0; 0|1=1; 1|0=1; 1|1=1


a=0o77print(a|3)print(a|3|7)


實例053:按位異或

題目 學習使用按位異或 ^ 。


程序分析 0^0=0; 0^1=1; 1^0=1; 1^1=0


a=0o77print(a^3)print(a^3^7)


實例054:位取反、位移動

題目 取一個整數a從右端開始的4~7位。


程序分析 可以這樣考慮:

(1)先使a右移4位。

(2)設置一個低4位全爲1,其餘全爲0的數。可用(0<<4)

(3)將上面二者進行&運算。


a=int(input('輸入一個數字: '))b=0                 #     0b=~b                #     1b=b<<4              # 10000b=~b                #  1111c=a>>4d=c&bprint('a:',bin(a))print('b:',bin(b))print('c:',bin(c))print('d:',bin(d))



實例055:按位取反

題目 學習使用按位取反~。


程序分析 ~0=1; ~1=0;


print(~234)print(~~234)


實例056:畫圈

題目 畫圖,學用circle畫圓形。


程序分析 無。


from tkinter import *canvas=Canvas(width=800,height=600,bg='yellow')canvas.pack(expand=YES,fill=BOTH)k=1j=1for i in range(26):    canvas.create_oval(310-k,250-k,310+k,250+k,width=1)    k+=j    j+=0.3mainloop()


實例057:畫線

題目 畫圖,學用line畫直線。


程序分析 無。


if __name__ == '__main__':    from tkinter import *
canvas = Canvas(width=300, height=300, bg='green') canvas.pack(expand=YES, fill=BOTH) x0 = 263 y0 = 263 y1 = 275 x1 = 275 for i in range(19): canvas.create_line(x0,y0,x0,y1, width=1, fill='red') x0 = x0 - 5 y0 = y0 - 5 x1 = x1 + 5 y1 = y1 + 5
x0 = 263 y1 = 275 y0 = 263 for i in range(21): canvas.create_line(x0,y0,x0,y1,fill = 'red') x0 += 5 y0 += 5 y1 += 5
mainloop()



實例058:畫矩形

題目 畫圖,學用rectangle畫方形。


程序分析 無。


if __name__ == '__main__':    from tkinter import *    root = Tk()    root.title('Canvas')    canvas = Canvas(root,width = 400,height = 400,bg = 'yellow')    x0 = 263    y0 = 263    y1 = 275    x1 = 275    for i in range(19):        canvas.create_rectangle(x0,y0,x1,y1)        x0 -= 5        y0 -= 5        x1 += 5        y1 += 5
canvas.pack() root.mainloop()


實例059:畫圖(醜)

題目 畫圖,綜合例子。


程序分析 醜。


if __name__  == '__main__':    from tkinter import *    canvas = Canvas(width = 300,height = 300,bg = 'green')    canvas.pack(expand = YES,fill = BOTH)    x0 = 150    y0 = 100    canvas.create_oval(x0 - 10,y0 - 10,x0 + 10,y0 + 10)    canvas.create_oval(x0 - 20,y0 - 20,x0 + 20,y0 + 20)    canvas.create_oval(x0 - 50,y0 - 50,x0 + 50,y0 + 50)    import math    B = 0.809    for i in range(16):        a = 2 * math.pi / 16 * i        x = math.ceil(x0 + 48 * math.cos(a))        y = math.ceil(y0 + 48 * math.sin(a) * B)        canvas.create_line(x0,y0,x,y,fill = 'red')    canvas.create_oval(x0 - 60,y0 - 60,x0 + 60,y0 + 60)


for k in range(501): for i in range(17): a = (2 * math.pi / 16) * i + (2 * math.pi / 180) * k x = math.ceil(x0 + 48 * math.cos(a)) y = math.ceil(y0 + 48 + math.sin(a) * B) canvas.create_line(x0,y0,x,y,fill = 'red') for j in range(51): a = (2 * math.pi / 16) * i + (2* math.pi / 180) * k - 1 x = math.ceil(x0 + 48 * math.cos(a)) y = math.ceil(y0 + 48 * math.sin(a) * B) canvas.create_line(x0,y0,x,y,fill = 'red') mainloop()


實例060:字符串長度

題目 計算字符串長度。


程序分析 無。


s='zhangguang101'print(len(s))



實例061:楊輝三角

題目 打印出楊輝三角形前十行。


程序分析 無。


def generate(numRows):    r = [[1]]    for i in range(1,numRows):        r.append(list(map(lambda x,y:x+y, [0]+r[-1],r[-1]+[0])))    return r[:numRows]a=generate(10)for i in a:    print(i)



實例062:查找字符串

題目 查找字符串。


程序分析 無。


s1='aabbxuebixuebi's2='ab's3='xue'print(s1.find(s2))print(s1.find(s3))



實例063:畫橢圓

題目 畫橢圓。


程序分析 使用 tkinter。


if __name__ == '__main__':    from tkinter import *    x = 360    y = 160    top = y - 30    bottom = y - 30
canvas = Canvas(width = 400,height = 600,bg = 'white') for i in range(20): canvas.create_oval(250 - top,250 - bottom,250 + top,250 + bottom) top -= 5 bottom += 5 canvas.pack() mainloop()


實例064:畫橢圓、矩形

題目 利用ellipse 和 rectangle 畫圖。。


程序分析 無。


if __name__ == '__main__':    from tkinter import *    canvas = Canvas(width = 400,height = 600,bg = 'white')    left = 20    right = 50    top = 50    num = 15    for i in range(num):        canvas.create_oval(250 - right,250 - left,250 + right,250 + left)        canvas.create_oval(250 - 20,250 - top,250 + 20,250 + top)        canvas.create_rectangle(20 - 2 * i,20 - 2 * i,10 * (i + 2),10 * ( i + 2))        right += 5        left += 5        top += 10

canvas.pack() mainloop()



實例065:畫組合圖形

題目 一個最優美的圖案。


程序分析 無。


import mathfrom tkinter import *

class PTS: def __init__(self): self.x = 0 self.y = 0points = []

def LineToDemo(): screenx = 400 screeny = 400 canvas = Canvas(width = screenx,height = screeny,bg = 'white')

AspectRatio = 0.85 MAXPTS = 15 h = screeny w = screenx xcenter = w / 2 ycenter = h / 2 radius = (h - 30) / (AspectRatio * 2) - 20 step = 360 / MAXPTS angle = 0.0 for i in range(MAXPTS): rads = angle * math.pi / 180.0 p = PTS() p.x = xcenter + int(math.cos(rads) * radius) p.y = ycenter - int(math.sin(rads) * radius * AspectRatio) angle += step points.append(p) canvas.create_oval(xcenter - radius,ycenter - radius, xcenter + radius,ycenter + radius) for i in range(MAXPTS): for j in range(i,MAXPTS): canvas.create_line(points[i].x,points[i].y,points[j].x,points[j].y)

canvas.pack() mainloop()if __name__ == '__main__': LineToDemo()



實例066:三數排序

題目 輸入3個數a,b,c,按大小順序輸出。


程序分析 同實例005。


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))



實例067:交換位置

題目 輸入數組,最大的與第一個元素交換,最小的與最後一個元素交換,輸出數組。


程序分析 無。


li=[3,2,5,7,8,1,5]

li[-1],li[li.index(min(li))]=li[li.index(min(li))],li[-1]

m=li[0]ind=li.index(max(li))li[0]=li[ind]li[ind]=m

print(li)



實例068:旋轉數列

題目 有n個整數,使其前面各數順序向後移m個位置,最後m個數變成最前面的m個數


程序分析 無。



from collections import *li=[1,2,3,4,5,6,7,8,9]deq=deque(li,maxlen=len(li))print(li)deq.rotate(int(input('rotate:')))print(list(deq))



實例069:報數

題目 有n個人圍成一圈,順序排號。從第一個人開始報數(從1到3報數),凡報到3的人退出圈子,問最後留下的是原來第幾號的那位。


程序分析 無。


if __name__ == '__main__':    nmax = 50    n = int(input('請輸入總人數:'))    num = []    for i in range(n):        num.append(i + 1)
i = 0 k = 0 m = 0
while m < n - 1: if num[i] != 0 : k += 1 if k == 3: num[i] = 0 k = 0 m += 1 i += 1 if i == n : i = 0
i = 0 while num[i] == 0: i += 1 print(num[i])



實例070:字符串長度II

題目 寫一個函數,求一個字符串的長度,在main函數中輸入字符串,並輸出其長度。


程序分析 無。


def lenofstr(s):    return len(s)

print(lenofstr('tanxiaofengsheng'))


實例071:輸入和輸出

題目 編寫input()和output()函數輸入,輸出5個學生的數據記錄。


程序分析 無。


N = 3#stu#num : string#name : string#score[4]: liststudent = []for i in range(5):    student.append(['','',[]])
def input_stu(stu): for i in range(N): stu[i][0] = input('input student num:\n') stu[i][1] = input('input student name:\n') for j in range(3): stu[i][2].append(int(input('score:\n')))
def output_stu(stu): for i in range(N): print ('%-6s%-10s' % ( stu[i][0],stu[i][1] )) for j in range(3): print ('%-8d' % stu[i][2][j])
if __name__ == '__main__': input_stu(student) print (student) output_stu(student)



實例072:創建鏈表

題目 創建一個鏈表。


程序分析 原文不太靠譜。


class Node:

def __init__(self, data): self.data = data self.next = None

def get_data(self): return self.data

class List:

def __init__(self, head): self.head = head

def is_empty(self): return self.get_len() == 0

def get_len(self): length = 0 temp = self.head while temp is not None: length += 1 temp = temp.next return length

def append(self, node): temp = self.head while temp.next is not None: temp = temp.next temp.next = node

def delete(self, index): if index < 1 or index > self.get_len(): print("給定位置不合理") return if index == 1: self.head = self.head.next return temp = self.head cur_pos = 0 while temp is not None: cur_pos += 1 if cur_pos == index-1: temp.next = temp.next.next temp = temp.next

def insert(self, pos, node): if pos < 1 or pos > self.get_len(): print("插入結點位置不合理") return temp = self.head cur_pos = 0 while temp is not Node: cur_pos += 1 if cur_pos == pos-1: node.next = temp.next temp.next =node break temp = temp.next

def reverse(self, head): if head is None and head.next is None: return head pre = head cur = head.next while cur is not None: temp = cur.next cur.next = pre pre = cur cur = temp head.next = None return pre

def print_list(self, head): init_data = [] while head is not None: init_data.append(head.get_data()) head = head.next return init_data

if __name__=='__main__': head=Node('head') link=List(head) for i in range(10): node=Node(i) link.append(node) print(link.print_list(head))



實例073:反向輸出鏈表

題目 反向輸出一個鏈表。


程序分析 無。


class Node:

def __init__(self, data): self.data = data self.next = None

def get_data(self): return self.data

class List:

def __init__(self, head): self.head = head

def is_empty(self): return self.get_len() == 0

def get_len(self): length = 0 temp = self.head while temp is not None: length += 1 temp = temp.next return length

def append(self, node): temp = self.head while temp.next is not None: temp = temp.next temp.next = node

def delete(self, index): if index < 1 or index > self.get_len(): print("給定位置不合理") return if index == 1: self.head = self.head.next return temp = self.head cur_pos = 0 while temp is not None: cur_pos += 1 if cur_pos == index-1: temp.next = temp.next.next temp = temp.next

def insert(self, pos, node): if pos < 1 or pos > self.get_len(): print("插入結點位置不合理") return temp = self.head cur_pos = 0 while temp is not Node: cur_pos += 1 if cur_pos == pos-1: node.next = temp.next temp.next =node break temp = temp.next

def reverse(self, head): if head is None and head.next is None: return head pre = head cur = head.next while cur is not None: temp = cur.next cur.next = pre pre = cur cur = temp head.next = None return pre

def print_list(self, head): init_data = [] while head is not None: init_data.append(head.get_data()) head = head.next return init_data

if __name__=='__main__': head=Node('head') link=List(head) for i in range(10): node=Node(i) link.append(node) print(link.print_list(head)) print(link.print_list(link.reverse(head)))



實例074:列表排序、連接

題目 列表排序及連接。


程序分析 排序可使用 sort() 方法,連接可以使用 + 號或 extend() 方法。


a=[2,6,8]b=[7,0,4]a.extend(b)a.sort()print(a)



實例075:不知所云

題目 放鬆一下,算一道簡單的題目。


程序分析 鬼知道是什麼。


if __name__ == '__main__':    for i in range(5):        n = 0        if i != 1: n += 1        if i == 3: n += 1        if i == 4: n += 1        if i != 4: n += 1        if n == 3: print (64 + i)



實例076:做函數

題目 編寫一個函數,輸入n爲偶數時,調用函數求1/2+1/4+…+1/n,當輸入n爲奇數時,調用函數1/1+1/3+…+1/n


程序分析 無。


def peven(n):    i = 0    s = 0.0    for i in range(2,n + 1,2):        s += 1.0 / i    return s
def podd(n): s = 0.0 for i in range(1, n + 1,2): s += 1.0 / i return s
def dcall(fp,n): s = fp(n) return s
if __name__ == '__main__': n = int(input('input a number: ')) if n % 2 == 0: sum = dcall(peven,n) else: sum = dcall(podd,n) print (sum)


實例077:遍歷列表

題目 循環輸出列表


程序分析 無。


l=['moyu','niupi','xuecaibichi','shengfaji','42']for i in range(len(l)):    print(l[i])



實例078:字典

題目 找到年齡最大的人,並輸出。請找出程序中有什麼問題。


程序分析 無。


if __name__ == '__main__':    person = {"li":18,"wang":50,"zhang":20,"sun":22}    m = 'li'    for key in person.keys():        if person[m] < person[key]:            m = key
print ('%s,%d' % (m,person[m]))


實例079:字符串排序

題目 字符串排序。


程序分析 無。


l=['baaa','aaab','aaba','aaaa','abaa']l.sort()print(l)


實例080:猴子分桃

題目 海灘上有一堆桃子,五隻猴子來分。第一隻猴子把這堆桃子平均分爲五份,多了一個,這隻猴子把多的一個扔入海中,拿走了一份。第二隻猴子把剩下的桃子又平均分成五份,又多了一個,它同樣把多的一個扔入海中,拿走了一份,第三、第四、第五隻猴子都是這樣做的,問海灘上原來最少有多少個桃子?


程序分析 無。


if __name__ == '__main__':    i = 0    j = 1    x = 0    while (i < 5) :        x = 4 * j        for i in range(0,5) :            if(x%4 != 0) :                break            else :                i += 1            x = (x/4) * 5 +1        j += 1    print(x)

for p in range(5): x=(x-1)/5*4 print(x)


實例081:求未知數

題目 809*??=800*??+9*?? 其中??代表的兩位數, 809*??爲四位數,8*??的結果爲兩位數,9*??的結果爲3位數。求??代表的兩位數,及809*??後的結果。


程序分析 無。


a = 809for i in range(10,100):    b = i * a    if b >= 1000 and b <= 10000 and 8 * i < 100 and 9 * i >= 100:        print(b,' = 800 * ', i, ' + 9 * ', i)
for i in range(10,100): if 8*i>99 or 9*i<100: continue if 809*i==800*i+9*i: print(i) break


實例082:八進制轉十進制

題目 八進制轉換爲十進制


程序分析 無。


n=eval('0o'+str(int(input('八進制輸入:'))))print(n)


實例083:製作奇數

題目 求0—7所能組成的奇數個數。


程序分析


組成1位數是4個。1,3,5,7結尾


組成2位數是7*4個。第一位不能爲0


組成3位數是784個。中間隨意


組成4位數是788*4個。


if __name__ == '__main__':    sum = 4    s = 4    for j in range(2,9):        print (sum)        if j <= 2:            s *= 7        else:            s *= 8        sum += s    print('sum = %d' % sum)



實例084:連接字符串

題目 連接字符串。


程序分析 無。


delimiter = ','mylist = ['Brazil', 'Russia', 'India', 'China']print(delimiter.join(mylist))


實例085:整除

題目 輸入一個奇數,然後判斷最少幾個 9 除於該數的結果爲整數。


程序分析 999999 / 13 = 76923。


if __name__ == '__main__':    zi = int(input('輸入一個數字:'))    n1 = 1    c9 = 1    m9 = 9    sum = 9    while n1 != 0:        if sum % zi == 0:            n1 = 0        else:            m9 *= 10            sum += m9            c9 += 1    print ('%d 個 9 可以被 %d 整除 : %d' % (c9,zi,sum))    r = sum / zi    print ('%d / %d = %d' % (sum,zi,r))



實例086:連接字符串II

題目 兩個字符串連接程序。


程序分析 無。


a='guangtou'b='feipang'print(b+a)



實例087:訪問類成員

題目 回答結果(結構體變量傳遞)。


程序分析 無。


if __name__ == '__main__':    class student:        x = 0        c = 0    def f(stu):        stu.x = 20        stu.c = 'c'    a= student()    a.x = 3    a.c = 'a'    f(a)    print(a.x,a.c)



實例088:打印星號

題目 讀取7個數(1—50)的整數值,每讀取一個值,程序打印出該值個數的*。


程序分析 無。


for i in range(3):    print('*'*int(input('input a number: ')))



實例089:解碼

題目 某個公司採用公用電話傳遞數據,數據是四位的整數,在傳遞過程中是加密的,加密規則如下:每位數字都加上5,然後用和除以10的餘數代替該數字,再將第一位和第四位交換,第二位和第三位交換。


程序分析 無。


n=input()n = str(n)a=[]for i in range(4):    a.append(int(n[i])+5)a[0],a[3]=a[3],a[0]a[1],a[2]=a[2],a[1]print ("".join('%s' %s for s in a))



實例090:列表詳解

題目 列表使用實例。


程序分析 無。


#list  #新建列表 testList=[10086,'中國移動',[1,2,4,5]]  
#訪問列表長度 print (len(testList) )#到列表結尾 print (testList[1:])#向列表添加元素 testList.append('i\'m new here!')
print (len(testList) )print (testList[-1] )#彈出列表的最後一個元素 print (testList.pop(1) )print (len(testList) )print (testList )st comprehension #後面有介紹,暫時掠過 matrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] print (matrix )print (matrix[1] )col2 = [row[1] for row in matrix]#get a column from a matrix print (col2 )col2even = [row[1] for row in matrix if row[1] % 2 == 0]#filter odd item print (col2even)


實例091:time模塊

題目 時間函數舉例1。


程序分析 無。


if __name__ == '__main__':    import time    print (time.ctime(time.time()))    print (time.asctime(time.localtime(time.time())))    print (time.asctime(time.gmtime(time.time())))



實例092:time模塊II

題目 時間函數舉例2。


程序分析 如何浪費時間。


if __name__ == '__main__':    import time    start = time.time()    for i in range(3000):        print(i)    end = time.time()
print (end - start)



實例093:time模塊III

題目 時間函數舉例3。


程序分析 如何浪費時間。


if __name__ == '__main__':    import time    start = time.clock()    for i in range(100):        print(i)    end = time.clock()    print('different is %6.3f' % (end - start))



實例094:time模塊IV

題目 時間函數舉例4。


程序分析 如何浪費時間。


if __name__ == '__main__':    import time    import random
play_it = input('do you want to play it.(\'y\' or \'n\')') while play_it == 'y': c = input('input a character:\n') i = random.randint(0,2**32) % 100 print ('please input number you guess:\n') start = time.clock() a = time.time() guess = int(input('input your guess:\n')) while guess != i: if guess > i: print('please input a little smaller') guess = int(input('input your guess:\n')) else: print('please input a little bigger') guess = int(input('input your guess:\n')) end = time.clock() b = time.time() var = (end - start) / 18.2 print (var) # print 'It took you %6.3 seconds' % time.difftime(b,a)) if var < 15: print ('you are very clever!') elif var < 25: print ('you are normal!') else: print ('you are stupid!') print ('Congradulations') print ('The number you guess is %d' % i) play_it = input('do you want to play it.')



實例095:轉換時間格式

題目 字符串日期轉換爲易讀的日期格式。


程序分析 看看就得了,dateutil是個第三方庫。


from dateutil import parserdt = parser.parse("Aug 28 2015 12:00AM")print (dt)



實例096:計算復讀次數

題目 計算字符串中子串出現的次數。


程序分析 無。


s1='xuebixuebixuebixuebixuebixuebixuebixue's2='xuebi'print(s1.count(s2))



實例097:磁盤寫入

題目 從鍵盤輸入一些字符,逐個把它們寫到磁盤文件上,直到輸入一個 # 爲止。


程序分析 無。


if __name__ == '__main__':    from sys import stdout    filename = input('輸入文件名:\n')    fp = open(filename,"w")    ch = input('輸入字符串:\n')    while ch != '#':        fp.write(ch)        stdout.write(ch)        ch = input('')    fp.close()



實例098:磁盤寫入II

題目 從鍵盤輸入一個字符串,將小寫字母全部轉換成大寫字母,然後輸出到一個磁盤文件"test"中保存。


程序分析 無。


if __name__ == '__main__':    fp = open('test.txt','w')    string = input('please input a string:\n')    string = string.upper()    fp.write(string)    fp = open('test.txt','r')    print (fp.read())    fp.close()



實例099:磁盤讀寫

題目 有兩個磁盤文件A和B,各存放一行字母,要求把這兩個文件中的信息合併(按字母順序排列), 輸出到一個新文件C中。


程序分析 無。


if __name__ == '__main__':    import string    fp = open('test1.txt')    a = fp.read()    fp.close()
fp = open('test2.txt') b = fp.read() fp.close()
fp = open('test3.txt','w') l = list(a + b) l.sort() s = '' s = s.join(l) fp.write(s) fp.close()



實例100:列表轉字典

題目 列表轉換爲字典。


程序分析 無。

i = ['a', 'b']l = [1, 2]print (dict(zip(i,l)))



       
       
       

回覆下方 「關鍵詞」,獲取優質資源


回覆關鍵詞 「linux」,即可獲取 185 頁 Linux 工具快速教程手冊和154頁的Linux筆記。


回覆關鍵詞 「Python進階」,即可獲取 106 頁 Python 進階文檔 PDF


回覆關鍵詞 「Python面試題」,即可獲取最新 100道 面試題 PDF


回覆關鍵詞 「python數據分析」,即可獲取47頁python數據分析與自然語言處理的 PDF


回覆關鍵詞 「python爬蟲」,滿滿五份PPT爬蟲教程和70多個案例


回覆關鍵詞 「Python最強基礎學習文檔」,即可獲取 168 頁 Python 最強基礎學習文檔 PDF,讓你快速入門Python

推薦我的微信號

來圍觀我的朋友圈,我的經驗分享,技術更新,不定期送書,坑位有限,速速掃碼添加!
備註:開發方向_暱稱_城市,另送你10本Python電子書。

點個在看你最好看


本文分享自微信公衆號 - 印象Python(Python_logic)。
如有侵權,請聯繫 [email protected] 刪除。
本文參與“OSC源創計劃”,歡迎正在閱讀的你也加入,一起分享。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章