99偷拍视频精品区一区二,口述久久久久久久久久久久,国产精品夫妇激情啪发布,成人永久免费网站在线观看,国产精品高清免费在线,青青草在线观看视频观看,久久久久久国产一区,天天婷婷久久18禁,日韩动漫av在线播放直播

Python學(xué)習:基礎(chǔ)練習題

1.輸出0到100的數(shù)字,如果數(shù)字是3的倍數(shù)輸出Fizz,5的倍數(shù)輸出Buzz。

創(chuàng)新互聯(lián)建站是網(wǎng)站建設(shè)技術(shù)企業(yè),為成都企業(yè)提供專業(yè)的網(wǎng)站設(shè)計制作、成都網(wǎng)站制作,網(wǎng)站設(shè)計,網(wǎng)站制作,網(wǎng)站改版等技術(shù)服務(wù)。擁有十余年豐富建站經(jīng)驗和眾多成功案例,為您定制適合企業(yè)的網(wǎng)站。十余年品質(zhì),值得信賴!

同時是3和5的倍數(shù)輸出FizzBuzz,其他情況則打印原數(shù)字

for i in range(100):
    if i==0:
        print(i)
    elif i%3==0 and i%5==0:
        print("FizzBuzz")
    elif i%3==0:
        print("Fizz")
    elif i%5==0:
        print("Buzz")
    else:
        print(i)

ps:條件語句依次執(zhí)行,滿足第一個條件后不會執(zhí)行下一個條件。所以同時滿足3和5的需要放在上面。

2.根據(jù)輸入的數(shù)字,打印相對應(yīng)層數(shù)的等腰三角形星星塔

ps:先打印空格,空格數(shù)量:總層數(shù)-當前層數(shù)。再打印星星,星星數(shù)量:當前層數(shù)*2-1

num = int(input("輸入一個數(shù)字:"))
for i in range(1,num+1):#外層循環(huán)定義 星星塔層數(shù)
    y = num-i#計算出空格要打印的次數(shù)
    print(" "*y,end="")#打印空行
    for j in range(1,2*i):#每行星星的數(shù)量
        print("*",end="")
    print()

如range(1,7),生成的數(shù)列是1到6,所以需要通過num+1的方式來控制層數(shù)

print()里end=""可以讓打印時不換行

2*i是星星的數(shù)量,利用range()自動減一。-、

使用while循環(huán)實現(xiàn)

num = int(input("輸入一個數(shù)字:"))
row=1
while row<=num:
    print(" "*(num-row)+"*"*(2*row-1))
    row+=1

row為層數(shù),默認為第一層

num-row為空格數(shù)量

2*row-1位星星數(shù)量

3.有1,2,3,4四個數(shù)字,能組成多少個互不相同且不重復(fù)的三位數(shù)字

list = []
sum = 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:
                num=i*100+j*10+k
                list.append(num)
                sum+=1
print(list)
print(sum)

三個數(shù)字可填在個十百位上,組成所有排列然后去掉重復(fù)的

4.遞歸返回None值

def get_op():
    str = input("請輸入你的選擇1/2/3/4:")
    try:
        no = int(str)
        if no not in[1,2,3,4]:
            print("請輸入正確的運算符")
            get_op()    #這里前面應(yīng)該加上return
        else:
            return no
    except ValueError as f:
        print("請輸入正確的運算符")
        get_op()    #這里前面應(yīng)該加上return

operator = get_op()
print(operator)

輸出

請輸入你的選擇1/2/3/4:a
請輸入正確的運算符
請輸入你的選擇1/2/3/4:11
請輸入正確的運算符
請輸入你的選擇1/2/3/4:1
None

在做下面一題的時候,我如果直接輸1到4是沒有問題的,但是如果輸入不是數(shù)字,或者不是1到4的數(shù)字,會返回None值

后來查了很多才發(fā)現(xiàn)。這樣寫遞歸調(diào)用后產(chǎn)生的值并沒有return出來,要在遞歸函數(shù)調(diào)用前加上return。把值一層層傳出去。

def get_op():
    str = input("請輸入你的選擇1/2/3/4:")
    try:
        no = int(str)
        if no not in[1,2,3,4]:
            print("請輸入正確的運算符")
            return get_op()
        else:
            return no
    except ValueError as f:
        print("請輸入正確的運算符")
        return get_op()

operator = get_op()
print(operator)

輸出

請輸入你的選擇1/2/3/4:a
請輸入正確的運算符
請輸入你的選擇1/2/3/4:22
請輸入正確的運算符
請輸入你的選擇1/2/3/4:2
2

5.編寫一個程序,提示“選擇運算符”,輸入“1/2/3/4”后,繼續(xù)輸入要進行運算的兩個數(shù)字后,打印出運算結(jié)果

def add(n1,n2):
    value = n1+n2
    print("%d + %d = %d"%(n1,n2,value))

def minus(n1,n2):
    value = n1-n2
    print("%d - %d = %d"%(n1,n2,value))

def multiply(n1,n2):
    value = n1*n2
    print("%d * %d = %d"%(n1,n2,value))

def divide(n1,n2):
    value = n1/n2
    print("%d / %d = %d"%(n1,n2,value))

dict={1:add,2:minus,3:multiply,4:divide}

def get_op():
    str = input("請輸入你的選擇1/2/3/4:")
    try:
        no = int(str)
        if no not in dict:
            print("請輸入正確的運算符")
            return get_op()#一定要return 遞歸,不然返回值是none
        else:
            return no
    except ValueError as f:
        print("請輸入正確的運算符")
        return get_op()

def get_num1():
    str = input("輸入第一個數(shù):")
    try:
        num = int(str)
        return num
    except ValueError as f:
        print("請輸入整數(shù)")
        return get_num1()

def get_num2():
    str = input("輸入第二個數(shù):")
    try:
        num = int(str)
        return num
    except ValueError as f:
        print("請輸入整數(shù)")
        return get_num1()

print("選擇運算:\n1 is +\n2 is -\n3 is *\n4 is /")
operator = get_op()
num1=get_num1()
num2=get_num2()
dict[operator](num1,num2)

ps:這個做了很久,一個是遞歸返回值的問題。還有一個通過字典存放函數(shù)指針。減少代碼量

前四個是加減乘除的函數(shù),然后存放到字段里,然后字典名[key](函數(shù)的參數(shù))這樣的形式調(diào)用。就不用寫很多判斷的代碼。

6.冒泡排序,數(shù)組之間相鄰值,兩兩進行比較。然后從大到小,或者從小到大排序

'''
學(xué)習中遇到問題沒人解答?小編創(chuàng)建了一個Python學(xué)習交流群:
尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學(xué)習教程和PDF電子書!
'''
ls = [7,12,34,4,24,20,11]
for i in range(len(ls)-1):#外層決定比較的輪次
    for j in range(len(ls)-1-i):#多少個數(shù)進行兩兩比較
        if ls[j] < ls[j+1]:#兩兩比較大小  <是從大到小排序  >是從小到大排序
            ls[j],ls[j+1] = ls[j+1],ls[j]#互換位置

print(ls)

輸出

[34, 24, 20, 12, 11, 7, 4]

數(shù)組的下標是從0開始的

從大到小排是找出最小的放到最后面,從小到大排是找出最大的放到最后面

ps:以上圖從大到小排序為例。第一輪是7個數(shù)進行比較,然后比較出最小的值放在最后。然后第二輪比較前6個值。以此類推。剩下2個數(shù)的時候,一次比完。所以需要比的輪次是 數(shù)組的長度減去1 。每輪需要比較數(shù)量,第一輪是數(shù)組長度,之后每輪減1.

7.二分查詢,對一個有序的數(shù)組進行查詢,從數(shù)組中間取出一個值,和需要查詢的值進行對比。

如果大于需要查詢的值,則取左邊一半繼續(xù)進行二分查詢。如果小于需要查詢的值,則取右邊一半繼續(xù)進行二分查詢。如果相同,則給出下標。沒有提示沒找到

使用循環(huán)實現(xiàn)

ls = [10,20,30]
def binary_search(alist,item):
    left =0 #下標最小值
    right = len(alist)-1   #下標最大值
    while left<=right:  #一定要有=,不然數(shù)組第一或最后一個無法查詢到
        numb = int((left+right)/2)  #中間值的下標
        if item == alist[numb]: #相等直接返回下標
            return numb
        elif item > alist[numb]:    #查詢的值大于數(shù)組中間值
            left = numb+1  #更新區(qū)間下標
        else:
            right = numb-1    #更新區(qū)間下標
    return None
s = binary_search(ls,20)
print(s)

left和right確定數(shù)組下標區(qū)間,找到中間值,比較大小后,根據(jù)升序還是降序的排序方式。來確定更換左邊還是右邊的下標。

一定要<= 因為數(shù)組最小或最大時,left=right

left一定要+1,不然會導(dǎo)致查詢數(shù)組最大時,取中間值下標這步出現(xiàn)死循環(huán)

使用遞歸實現(xiàn)

ls = [10,20,30]
def binary_search(alist,item,left,right):
    if left > right:
        return None
    numb = int((left+right)/2) 
    if alist[numb] == item:
        return numb
    elif item > alist[numb]:  
        return binary_search(alist,item,numb+1,right)
    else:
        return binary_search(alist,item,left,numb-1)
s = binary_search(ls,10,0,3)
print(s)

本文標題:Python學(xué)習:基礎(chǔ)練習題
網(wǎng)站網(wǎng)址:http://www.yijiale78.com/article40/dsogeeo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版定制網(wǎng)站自適應(yīng)網(wǎng)站手機網(wǎng)站建設(shè)App開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

手機網(wǎng)站建設(shè)