Pythonの基本的な知識(2):条件付きステートメント、ループステートメント、推論

ここに写真の説明を挿入

1条件付きステートメント

1.1ifステートメント

if expression:
    expr_true_suite
  • expr_true_suiteコードのステートメントブロックがexpression実装されている場合に条件式がtrueの場合のみ、それ以外の場合は、コードブロックの直後でステートメントを実行し続けます。
  • expressionブール演算子による条件式の場合単一のステートメントandorありnot、複数の条件付きを実現します。

【例】

if 2 > 1 and not 2 > 3:
    print('Correct Judgement!')
# Correct Judgement!

1.2if-elseステートメント

if expression:
    expr_true_suite
else
    expr_false_suite
  • Pythonは、ifステートメントの条件式の結果がfalseの場合、ifで使用されるelseを提供し、プログラムはelseステートメントの後にコードを実行します。

【例】

temp = input("猜一猜小仙女想的是哪个数字?")
guess = int(temp) # input 函数将接收的任何数据类型都默认为 str。
if guess == 666:
    print("你太了解小仙女的心思了!")
    print("哼,猜对也没有奖励!")
else:
    print("猜错了,小仙女现在心里想的是666!")
print("游戏结束,不玩儿啦!")

ifセンテンスはネストをサポートします。つまり、あるifセンテンスが別のifセンテンスに埋め込まれて、異なるレベルの選択構造を形成します。Pythonは、中括弧の代わりにインデントを使用してコードブロックの境界をマークするためelse、ハングの問題に特に注意してください。
【例】

hi = 6
if hi > 2:
    if hi > 7:
        print('好棒!好棒!')
else:
    print('切~')

1.3if-elif-elseステートメント

if expression1:
    expr1_true_suite
elif expression2:
    expr2_true_suite
    .
    .    
elif expressionN:
    exprN_true_suite
else:
    expr_false_suite
  • elifステートメントはelseifであり、複数の式がtrueであるかどうかを確認し、trueの場合は特定のコードブロックでコードを実行するために使用されます。

【例】

temp = input('请输入成绩:')
source = int(temp)
if 100 >= source >= 90:
    print('A')
elif 90 > source >= 80:
    print('B')
elif 80 > source >= 60:
    print('C')
elif 60 > source >= 0:
    print('D')
else:
    print('输入错误!')

1.4キーワードをアサート

  • assert式を判断し、式の条件がfalseの場合にAssertionError例外をトリガーするために使用されます
    アサーションは、条件が満たされていない場合にプログラムが実行されると、実行後にプログラムがクラッシュするのを待たずに、エラーを直接返すことができます。たとえば、コードはLinuxシステムでのみ実行できます。最初に、現在のシステムが条件を満たしているかどうかを判断できます。

【例】

my_list = ['lsgogroup']
my_list.pop(0)
assert len(my_list) > 0
# AssertionError
  • ユニットテスト中に、プログラムにチェックポイントを設定するために使用できます。プログラムが正常に動作できるのは、条件がTrueの場合のみです。
    【例】
assert 3 > 7
# AssertionError

2ループステートメント

2.1whileループ

whileステートメントの最も基本的な形式には、上部にブール式があり、whileコードブロックに属する1つ以上のインデントされたステートメントが含まれます。

while 布尔表达式:
    代码块

whileループされたコードブロックは、ブール式の値がブールfalseになるまでループを続けます。
ブール式に<、>、==、!=、in、not in等しい演算子がない場合は、値などの条件のみを指定することもできます。場合にwhileゼロ以外の整数を後で書き込まれ、それが真の値とみなされ、ループ本体が実行され、0場合書き込まれ、それが偽の値とみなされ、ループ本体は実行されません。str、listまたは任意のシーケンスを書き込むこともできます。ゼロ以外の長さは真の値と見なされてループ本体が実行されます。それ以外の場合は、偽の値と見なされてループ本体は実行されません。

【例】

count = 0
while count < 3:
    temp = input("不妨猜一下小哥哥现在心里想的是那个数字:")
    guess = int(temp)
    if guess > 8:
        print("大了,大了")
    else:
        if guess == 8:
            print("你是小哥哥心里的蛔虫吗?")
            print("哼,猜对也没有奖励!")
            count = 3
        else:
            print("小了,小了")
    count = count + 1
print("游戏结束,不玩儿啦!")

【例】ブール式は0を返し、ループが終了します。

string = 'abcd'
while string:
    print(string)
    string = string[1:]
# abcd
# bcd
# cd
# d

2.2while-elseループ

while 布尔表达式:
    代码块
else:
    代码块

場合whileループが正常に実行され、else出力がwhile実行されている。場合はループの外にジャンプ文がループ内で実行され、例えばbreakelseコードブロックの内容は実行されません
【例】

count = 0
while count < 5:
    print("%d is  less than 5" % count)
    count = count + 1
else:
    print("%d is not less than 5" % count)    
# 0 is  less than 5
# 1 is  less than 5
# 2 is  less than 5
# 3 is  less than 5
# 4 is  less than 5
# 5 is not less than 5

【例】

count = 0
while count < 5:
    print("%d is  less than 5" % count)
    count = 6
    break
else:
    print("%d is not less than 5" % count)
# 0 is  less than 5

2.3forループ

forループは反復ループであり、Pythonの一般的なシーケンス反復子と同等であり、などの順序付けられたシーケンスをトラバースできstr、list、tuple、。などの反復可能なオブジェクトもトラバースできますdict

for 迭代变量 in 可迭代对象:
    代码块

各ループで、反復変数は反復可能オブジェクトの現在の要素に設定され、コードブロックに提供されます。
【例】

for i in 'ILoveMAOMAO':
    print(i, end=' ')  # 不换行输出
# I L o v e M A O M A O

【例】

member = ['张三', '李四', '刘德华', '刘六', '周润发']
for i in range(len(member)):
    print(member[i])
# 张三
# 李四
# 刘德华
# 刘六
# 周润发

【例】

dic = {
    
    'a': 1, 'b': 2, 'c': 3, 'd': 4}
for key, value in dic.items():
    print(key, value, sep=':', end=' ')    
# a:1 b:2 c:3 d:4 

2.4for-elseループ

for 迭代变量 in 可迭代对象:
    代码块
else:
    代码块

ときにforループが正常に実行され、else出力がfor実行される。場合はループの外にジャンプ文がループ内で実行され、例えばbreakelseコードブロックの内容は実行されませんwhile - elseただ文のよう。
【例】

for num in range(10, 20):  # 迭代 10 到 20 之间的数字
    for i in range(2, num):  # 根据因子迭代
        if num % i == 0:  # 确定第一个因子
            j = num / i  # 计算第二个因子
            print('%d 等于 %d * %d' % (num, i, j))
            break  # 跳出当前循环
    else:  # 循环的 else 部分
        print(num, '是一个质数')
# 10 等于 2 * 5
# 11 是一个质数
# 12 等于 2 * 6
# 13 是一个质数
# 14 等于 2 * 7
# 15 等于 3 * 5
# 16 等于 2 * 8
# 17 是一个质数
# 18 等于 2 * 9
# 19 是一个质数

breakステートメントは、現在のレイヤーのループから飛び出すことができます。
continueこのサイクルを終了し、次のサイクルを開始します。
passこれは空のステートメントであり、操作を行わず、プレースホルダーとしてのみ機能し、その役割はプログラム構造の整合性を維持することです。

3イテレーター

3.1 range()関数

range([start,] stop[, step=1])
  • このBIF(組み込み関数)には3つのパラメーターがあり、そのうちの2つは角括弧で囲まれており、これら2つのパラメーターがオプションであることを示しています。
  • step=1 3番目のパラメーターのデフォルト値が1であることを示します。
  • rangeこのBIFの機能はstartstopパラメーターの値で始まり、パラメーターの値で終わる一連の番号を生成することです。シーケンスにはstart値が含まれていますが、stopは含まれていません

【例】

for i in range(2, 5):  # 不包含9
    print(i)
# 2
# 3
# 4

3.2 enumerate()関数

enumerate(sequence, [start=0])
  • シーケンス-シーケンス、イテレーター、または反復をサポートするその他のオブジェクト。
  • start-添え字の開始位置。
  • 列挙(列挙)オブジェクトを返す
    [例]
seasons = ['Spring', 'Summer', 'Fall', 'Winter']
lst = list(enumerate(seasons))
print(lst)
# [(0, 'Spring'), (1, 'Summer'), (2, 'Fall'), (3, 'Winter')]

lst = list(enumerate(seasons, start=1))  # 下标从 1 开始
print(lst)
# [(1, 'Spring'), (2, 'Summer'), (3, 'Fall'), (4, 'Winter')]

enumerate()forループとの併用

for i, a in enumerate(A)
    do something with a  

enumerate(A)のみ返すA要素を、要素は、(デフォルトでゼロから)インデックス値をポイントです。さらに、withenumerate(A, j)は、インデックスの開始値を決定することもできますj
【例】

languages = ['Python', 'R', 'Matlab', 'C++']
for language in languages:
    print('I love', language)
print('Done!')
'''
I love Python
I love R
I love Matlab
I love C++
Done!
'''

4派生物

4.1リストの理解

[ expr for value in collection [if condition] ]

【例】

x = [i ** 2 for i in range(1, 10)]
print(x)
# [1, 4, 9, 16, 25, 36, 49, 64, 81]

【例】

x = [(i, i ** 2) for i in range(6)]
print(x)
# [(0, 0), (1, 1), (2, 4), (3, 9), (4, 16), (5, 25)]

【例】

x = [i for i in range(100) if (i % 2) != 0 and (i % 3) == 0]
print(x)
# [3, 9, 15, 21, 27, 33, 39, 45, 51, 57, 63, 69, 75, 81, 87, 93, 99]

4.2タプルの理解

( expr for value in collection [if condition] )

【例】

a = (x for x in range(10))
print(a)
# <generator object <genexpr> at 0x0000025BE511CC48>
print(tuple(a))
# (0, 1, 2, 3, 4, 5, 6, 7, 8, 9)

4.3辞書の理解

{
    
     key_expr: value_expr for value in collection [if condition] }

【例】

b = {
    
    i: i % 2 == 0 for i in range(10) if i % 3 == 0}
print(b)
# {0: True, 3: False, 6: True, 9: False}

4.4理解度を設定する

{ expr for value in collection [if condition] }

【例】

c = {
    
    i for i in [1, 2, 3, 4, 5, 5, 6, 4, 3, 2, 1]}
print(c)
# {1, 2, 3, 4, 5, 6}

練習問題
1。Pythonプログラムを作成して、1500から2700の間で7と5で割り切れる数を見つけます。

# your code here 
[i for i in range(1500,2700,1) if i%7 == 0 and i%5 == 0]

2.カメとカメのゲーム
タイトルの説明:
この世界にはあらゆる種類のウサギとカメがいるとしましょう。しかし、調査によると、すべてのウサギとカメには共通の特徴があります。彼らはレースが好きです。その結果、世界各地で亀とうさぎのレースが絶えず行われているXiaohuaはこれに非常に興味を持っているので、異なるうさぎと亀の間のレースを研究することにしました。彼は、ウサギはカメよりも速く走るが、よく知られている問題があることを発見しました-誇りと怠惰です。したがって、カメとのゲームでは、ウサギが1秒後にtメートル以上先にいると、ウサギは止まります。 s秒間休憩します。ウサギが異なれば、tとsの値も異なりますが、すべてのカメは同じです-最後に達したときに止まることはありません。
ただし、一部のゲームは非常に長く、表示プロセス全体に時間がかかります。Xiaohuaは、各ゲームの開始後にウサギと亀のデータが記録されている限り、ウサギの速度v1(つまり、ウサギは毎秒v1メートルを実行できることを意味します)、亀の速度v2、ウサギに対応するtとsの値、およびトラックlの長さ-レースの結果を予測できます。しかし、Xiaohuaは怠惰で、ゲームの結果を推測するために手動計算を使用したくないので、Tsinghua大学のコンピューターサイエンス学部の才能ある学生であるあなたに助けを求めました。プログラムを作成してください。ゲームの入力データv1については、 v2、t、s、lは、ゲームの結果を予測します。
入力:入力
行は1行のみで、スペースで区切られた5つの正の整数v1、v2、t、s、lが含まれます。ここで、(v1、v2 <= 100; t <= 300; s <= 10; l <= 10000およびこれはv1、v2)の一般的な倍数です。
出力:
出力には2行が含まれ、最初の行にはゲームの結果が出力されます。それぞれ大文字の「T」または「R」または「D」で、亀が勝つか、ウサギが勝つか、または両方が同時に到着することを示します。終わり。
2行目は正の整数を出力し、勝者(または両側)が終点に到達するまでにかかる時間(秒単位)を示します。


サンプル入力:
10 5 5 2 20
サンプルの出力
D

4

# your code here 
class Turtle_rabbit:
    def run(self,inputs):
        v1,v2,t,s,l = inputs
        result = []
        dist1,dist2 = 0, 0
        i = 0
        while dist1 < l and dist2 < l:
            dist1 += v1
            dist2 += v2
            i +=1
            if(dist1 == l or dist2 == l):
                break
            if(dist1 - dist2 >= t):
                dist1 -= s*v1    
                            
        if dist1 > dist2:
            result.append("R")
        elif dist1 < dist2:
            result.append("T")
        else:
            result.append("D") 
        result.append(i)
        return result
        
if __name__ == "__main__":
    inputs = (10,5,5,2,20)
    result = Turtle_rabbit()
    for i,data in enumerate(result.run(inputs)):
        print(data)

参考文献

  • https://www.runoob.com/python3/python3-tutorial.html
  • https://www.bilibili.com/video/av4050443
  • https://mp.weixin.qq.com/s/DZ589xEbOQ2QLtiq8mP1qQ

DataWhale

Datawhaleは、データサイエンスとAIに焦点を当てたオープンソース組織であり、多くの大学やこの分野の有名企業から優秀な学習者を集め、オープンソースと探索精神を持ったチームメンバーのグループを集めています。Datawhaleは、「学習者のために、学習者とともに成長する」というビジョンを掲げ、真の自己表現、開放性と寛容性、相互信頼と相互支援、間違いを犯そうとする勇気、責任を取る勇気を奨励しています。同時に、Datawhaleはオープンソースの概念を使用して、オープンソースコンテンツ、オープンソース学習とオープンソースソリューションを探索し、人材トレーニングを強化し、人材の成長を支援し、人と人、人と知識、人と企業、人と未来の間のつながりを確立します。

おすすめ

転載: blog.csdn.net/OuDiShenmiss/article/details/107533168