Python猜數(shù)字算法題詳解
今天刷的第一道算法題,先拿一道簡單點的試試手,這道題目的要求是:
兩個人甲乙在猜數(shù)字,甲先從1,2,3三個數(shù)字中隨機抽3次,結(jié)果是guess。乙隨后也隨機抽三次,結(jié)果是answer。然后對比甲乙兩個人的結(jié)果。示例如下:
guess:[1,2,3], answer: [1, 2, 3]
那么結(jié)果就是猜對了3次
guess: [1,2,3] answer:[3,2,1]
那么結(jié)果就是猜對了1次
guess: [1,2,3], answer:[3, 3,1]
那么結(jié)果就是猜對了0次
即將guess和answer兩個作為參數(shù)輸入,返回猜對的次數(shù)。
我想出來的幾個答案如下所示:
答案1:
class Solution:
def game(self, guess: List[int], answer: List[int]) -> int:
count = 0
for i in zip(guess, answer):
if i[0] == i[1]:
count += 1
return count
思路是:使用zip將兩個列表進行組合,返回每個列表中單個元素組成的元組,然后循環(huán)對比。如果相等就將臨時變量值+1,最終返回統(tǒng)計結(jié)果。
答案2:
class Solution:
def game(self, guess: List[int], answer: List[int]) -> int:
count = 0
for i in range(3):
if guess[i] == answer[i]:
count+=1
return count
思路:轉(zhuǎn)念一想,發(fā)現(xiàn)自己想復(fù)雜了,因為不需要拼接,就可以直接取這兩個列表對應(yīng)的值進行對比。就更簡單了,直接循環(huán)對比,有相等的情況將臨時變量+1,最后返回臨時變量即可。
答案3:
class Solution:
def game(self, guess: List[int], answer: List[int]) -> int:
return sum(map(lambda x,y: x==y, guess, answer))
思路:既然可以直接對比,那么能不能再簡單點,我就想到了map函數(shù),map函數(shù)第一個參數(shù)直接使用匿名函數(shù)來進行元素對比,然后收集函數(shù)執(zhí)行結(jié)果。如果對比相等,結(jié)果是True,對比不相等,結(jié)果是False。
最后返回map函數(shù)直接結(jié)果的總和即可。
答案4:
class Solution:
def game(self, guess: List[int], answer: List[int]) -> int:
if guess == answer:
return 3
elif guess[0] == answer[0]:
if guess[1] == answer[1]:
return 2
else:
return 1
elif guess[1] == answer[1]:
if guess[2] == answer[2]:
return 2
else:
return 1
elif guess[2] == answer[2]:
return 1
else:
return 0
思路:將guess和answer進行對比,這是我認為自己最差的一個答案,因為這種情況只適合這種簡短的列表對比,再長一點整個代碼就沒法看了。
內(nèi)容擴展:
Python初學(xué)者小游戲:猜數(shù)字
游戲邏輯:電腦隨機生成一個數(shù)字,然后玩家猜數(shù)字,電腦提示猜的數(shù)字大了還是小了,供玩家縮小數(shù)字范圍,達到既定次數(shù)后,玩家失敗。若在次數(shù)內(nèi)猜對,玩家獲勝。
涉及知識點:random.randint() , print() , input() ( raw_input() )
參考實現(xiàn)代碼:
#!/usr/bin/env python
# encoding: utf-8
#使用print("",end=...)標準
from __future__ import print_function
import os
import sys
import time
import random
#輸入檢測
while 1:
os.system('cls')
print ("Hello , Welcome to Guess_Number Games...The Number is between 1 - 10...")
print ("Please input the level you want(1~10): ",end = '')
level = raw_input("")
diff = 11-int(level)
if diff > 10 or diff <1:
print ("Invalid Input...")
time.sleep(0.3)
else:
break
#猜數(shù)字流程
count_num = 0
ran = random.randint(1,10)
while count_num < diff:
count_num += 1
print (str(count_num)+": "+"Please input the number you guess: ",end = '')
number = raw_input()
number = int(number)
if number < ran:
print ("Too Little...")
continue
elif number > ran:
print ("Too Big...")
continue
else:
print ("Congraduation! You Win...")
break
if count_num == diff:
print ("You Lose...")
到此這篇關(guān)于Python猜數(shù)字算法題詳解的文章就介紹到這了,更多相關(guān)Python實現(xiàn)猜數(shù)字內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Pycharm中如何關(guān)掉python console
這篇文章主要介紹了Pycharm中如何關(guān)掉python console,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10
關(guān)于Python的pymouse click 雙擊的問題
這篇文章主要介紹了關(guān)于Python的pymouse click 雙擊的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06
Python的json.loads() 方法與json.dumps()方法及使用小結(jié)
json.loads() 是一個非常有用的方法,它允許你在處理 JSON 數(shù)據(jù)時,將其轉(zhuǎn)換為 Python 數(shù)據(jù)類型,以便于在代碼中進行操作和處理,這篇文章給大家介紹Python的json.loads() 方法與json.dumps()方法及使用小結(jié),感興趣的朋友一起看看吧2024-03-03
Python企業(yè)編碼生成系統(tǒng)總體系統(tǒng)設(shè)計概述
這篇文章主要介紹了Python企業(yè)編碼生成系統(tǒng)總體系統(tǒng)設(shè)計,簡單描述了Python企業(yè)編碼生成系統(tǒng)的功能、結(jié)構(gòu)與相關(guān)編碼實現(xiàn)技巧,需要的朋友可以參考下2019-07-07
詳解python while 函數(shù)及while和for的區(qū)別
這篇文章主要介紹了python while 函數(shù)及while和for的區(qū)別 ,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2018-09-09
Python中利用all()來優(yōu)化減少判斷的實例分析
在本篇文章里小編給大家整理的是一篇關(guān)于Python中利用all()來優(yōu)化減少判斷的實例分析內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。2021-06-06

