熱心に練習する価値のある 100 の古典的な Python 練習問題 (詳細な回答付き)

皆さん、こんにちは。論文が再び登場しました。100 の古典的な Python の練習問題があります。

100 個の Python 演習を整理するのに 1 週​​間かかりました. 初心者の場合, この演習は大きな助けになります. この演習を完全に独力で完了することができる場合. 質問, あなたはすでに Python を使い始めています. Python の基本:

Python100 の古典的な練習問題と答えPython を学ぶとき、多くの友人が混乱することがあります. 彼らは自分のレベルが非常に高いかどうかを検出する方法を知りません. 今回はこれをお届けします 1 https://mp.weixin . qq.com/ s/wJKG2AsaCQxQhpK-rf2qwQ質問1

質問:

7 で割り切れるが 5 の倍数ではない数 (2000 から 3200 までの間) をすべて見つけるプログラムを作成してください。得られた数値は、コンマ区切りの順序で 1 行に出力する必要があります。

ヒント:

range(#begin, #end) メソッドの使用を検討してください。

私の解決策: Python 3

  • ループに使用

l=[]
for i in range(2000, 3201):
    if (i%7==0) and (i%5!=0):
        l.append(str(i))

print ','.join(l)
  • ジェネレーターとリスト内包表記の使用

print(*(i for i in range(2000, 3201) if i%7 == 0 and i%5 != 0), sep=",")

質問2

質問:

与えられた数の階乗を計算できるプログラムを書いてください。結果はコンマ区切りの順序で 1 行に表示されます。プログラムに次の入力が与えられたとします: 8 次に、出力は次のようになります: 40320

ヒント:

入力データが質問に提供される場合、それはコンソール入力であると見なされるべきです。

私の解決策: Python 3

  • 使用While循環环
    n = int(input()) #input() 関数は入力を文字列型として受け取ります
    #int() はそれを整数型に変換します
    fact = 1
    i = 1
    while i <= n:
    fact = fact * i;
    i = i + 1
    print(事実)

  • For Cycle环
    n = int(input()) #input() 関数は入力を文字列型として受け取ります
    #int() はそれを整数型に変換します
    fact = 1
    for i in range(1,n+1):
    fact = fact * i
    印刷(事実)

  • ラムダ関数の使用
    n = int(input())
    def shortFact(x): x <= 1 の場合は 1 を返す それ以外の場合は x*shortFact(x-1)
    print(shortFact(n))

while True:
try:
    num = int(input("Enter a number: "))
    break
except ValueError as err:
    print(err)

org = num
fact = 1
while num:
    fact = num * fact
    num = num - 1
print(f'the factorial of {org} is {fact}')
from functools import reduce

def fun(acc, item):
    return acc*item

num = int(input())
print(reduce(fun,range(1, num+1), 1))

質問 3

質問:

与えられた整数 n を使用して、(i, ixi) を 1 から n までの整数 (両端を含む) として含む辞書を生成するプログラムを作成します。次に、プログラムは辞書を出力する必要があります。次の入力がプログラムに与えられたと仮定します: 8 \
次に、出力は次のようになります。
{1: 1, 2: 4, 3: 9, 4: 16, 5: 25, 6: 36, 7: 49, 8: 64}

ヒント:

入力データが質問に提供される場合、それはコンソール入力であると見なされるべきです。dict() の使用を検討してください

私の解決策: Python 3:

  • ループに使用

n = int(input())
ans = {}
for i in range (1,n+1):
    ans[i] = i * i
print(ans)
  • 辞書理解を使用する

n = int(input())
ans={i : i*i for i in range(1,n+1)}
print(ans)
# 演进
try:
    num = int(input("Enter a number: "))
except ValueError as err:
    print(err)

dictio = dict()
for item in range(num+1):
    if item == 0:
        continue
    else:
	dictio[item] = item * item
print(dictio)
num = int(input("Number: "))
print(dict(enumerate([i*i for i in range(1, num+1)], 1)))

これらは初日で解決される問題です。上記の問題は、基本的な初心者の学習者にとって非常に簡単です。ソリューションでいくつかの簡単なコーディング方法を示します。翌日、新しい問題にどのように直面し、対処するかを見てみましょう。

質問

コンマで区切られた 4 桁の 2 進数列を入力として取り、それらが 5 で割り切れるかどうかを調べるプログラムを作成してください。5 で割り切れる数は、カンマ区切りで出力されます。
例:
0100,0011,1010,1001
次に、出力は次のようになります。
1010
注: データは、コンソール経由で入力されるものと想定されています。

ヒント:

入力データが質問に提供される場合、それはコンソール入力であると見なされるべきです。
def check(x):                       #转换二进制整数&返回由5零中频整除
    total, pw = 0, 1
    reversed(x)

    for i in x:
        total+=pw * (ord(i) - 48)    #ORD()函数返回ASCII值
        pw*=2
    return total % 5

data = input().split(",")           #输入此处,并在','位置分割
lst = []



for i in data:
    if check(i) == 0:              #如果零发现它是指由零整除并添加到列		lst.append(i)

print(",".join(lst))

また

def  check(x):#如果被5整除,则check函数返回true 
    return  int(x,2)%5  ==  0       #int(x,b)将x作为字符串,将b作为基数,
                                #将其转换为十进制
数据 = 输入()。分割(',')

data  =  list(filter(check(data)))#在filter(func,object)函数中,如果通过'check'函数
print(“,”。join(data)找到True,则从'data'中选取元素。

また

data = input().split(',')
data = [num for num in data if int(num, 2) % 5 == 0]
print(','.join(data))

質問12

質問:

1000 ~ 3000 (両端を含む) のすべての数字を検索し、数字のすべての桁が偶数になるプログラムを作成します。得られた数値は、コンマ区切りの順序で 1 行に出力する必要があります。

ヒント:

入力データが質問に提供される場合、それはコンソール入力であると見なされるべきです。

私の解決策: Python 3

lst = []

for i in range(1000,3001):
    flag = 1
    for j in str(i):         #每个整数编号i被转换成字符串
    
        if ord(j)%2 != 0:     #ORD返回ASCII值并且j是i
            flag = 0          
    if flag == 1:
        lst.append(str(i))   #i作为字符串存储在列表中

print(",".join(lst))

また

def check(element):
    return all(ord(i)%2 == 0 for i in element)  #所有返回true如果所有的数字,i是即使在元件

lst = [str(i) for i in range(1000,3001)]        #创建所有给定数字的列表,其字符串数据类型为
lst = list(filter(check,lst))                   #如果检查条件失败,则过滤器从列表中删除元素
print(",".join(lst))
lst = [str(i) for i in range(1000,3001)]
lst = list(filter(lambda i:all(ord(j)%2 == 0 for j in i), lst))   #使用lambda来在过滤器功能内部定义函数
print(",".join(lst))

質問13

質問:

文章を受け取って、文字と数字の数を数えるプログラムを書きなさい。
次の入力がプログラムに与えられたとします。
hello world! 123
次に、出力は次のようになります。
LETTERS 10
DIGITS 3

ヒント:

入力データが質問に提供される場合、それはコンソール入力であると見なされるべきです。
word = input()
letter,digit = 0,0

for i in word:
    if ('a'<=i and i<='z') or ('A'<=i and i<='Z'):
        letter+=1
    if '0'<=i and i<='9':
        digit+=1

print("LETTERS {0}\nDIGITS {1}".format(letter,digit))

また

word = input()
letter, digit = 0,0

for i in word:
    if i.isalpha(): #返回true如果字母表
        letter += 1
    elif i.isnumeric(): #返回true如果数字
        digit += 1
print(f"LETTERS {letter}\n{digits}") #两种解决方案均显示两种不同类型的格式化方法

10 ~ 13 を超えるすべての質問は、ほとんど文字列に関連しています。ソリューションの主要部分は、文字列置換関数と、コードを短い形式で書き留めるための理解メソッドで構成されています。

質問14

質問:

文の大文字と小文字の数を数えるプログラムを書きなさい。
次の入力がプログラムに与えられたとします。
Hello world!
次に、出力は次のようになります。
UPPER CASE 1
LOWER CASE 9

ヒント:

入力データが質問に提供される場合、それはコンソール入力であると見なされるべきです。

私の解決策: Python 3

word = input()
upper,lower = 0,0

for i in word:
    if 'a'<=i and i<='z' :
        lower+=1
    if 'A'<=i and i<='Z':
        upper+=1

print("UPPER CASE {0}\nLOWER CASE {1}".format(upper,lower))

また

word = input()
upper,lower = 0,0

for i in word:
        lower+=i.islower()
        upper+=i.isupper()

print("UPPER CASE {0}\nLOWER CASE {1}".format(upper,lower))

また

string = input("Enter the sentense")
upper = 0
lower = 0
for x in string:
    if x.isupper() == True:
        upper += 1
    if x.islower() == True:
        lower += 1

print("UPPER CASE: ", upper)
print("LOWER CASE: ", lower)

Python100 の古典的な練習問題と答えPython を学ぶとき、多くの友人が混乱することがあります. 彼らは自分のレベルが非常に高いかどうかを検出する方法を知りません. 今回はこれをお届けします 1 https://mp.weixin . qq.com/ s/wJKG2AsaCQxQhpK-rf2qwQ

おすすめ

転載: blog.csdn.net/m0_68507761/article/details/125015311