Python是一種完備、開放、通用的高級編程語言,它被廣泛應用于人工智能、數(shù)據分析、網絡爬蟲、游戲開發(fā)等領域。在編寫Python代碼時,決策結構是一個應該掌握好的核心知識點。決策結構指的是在執(zhí)行程序時,根據一定條件,執(zhí)行相應的代碼塊。Python有多種類型的決策結構,如條件語句、循環(huán)語句等。掌握這些結構可以提高代碼執(zhí)行效率,實現(xiàn)更加靈活復雜的邏輯控制。
一、條件語句
條件語句是在指定條件成立時執(zhí)行的語句。Python的條件語句包括:if語句、if...else語句、if...elif...else語句。
1、if語句
x = 15
if x > 10:
print("x 大于 10")
上面的代碼中,僅有一個if語句,判斷變量x是否大于10,如果條件成立,則執(zhí)行下一條語句,打印出"x 大于 10"。
2、if...else語句
x = 5
if x > 10:
print("x 大于 10")
else:
print("x 小于等于 10")
上面的代碼中,if語句和else語句共同組成了一個if...else語句。如果條件成立,則執(zhí)行if語句,否則執(zhí)行else語句。如果x大于10,則輸出"x 大于 10";否則輸出"x 小于等于 10"。
3、if...elif...else語句
x = 5
if x > 10:
print("x 大于 10")
elif x > 5:
print("x 大于 5,小于等于 10")
else:
print("x 小于等于 5")
上面的代碼中,if語句、elif語句和else語句共同組成了一個if...elif...else語句。依次判斷條件,如果第一個if條件成立,則輸出"x 大于 10";如果第一個if條件不成立,且第一個elif條件成立,則輸出"x 大于 5,小于等于 10";如果以上兩個條件都不成立,則輸出"x 小于等于 5"。
二、循環(huán)語句
循環(huán)語句是在滿足一定條件下,重復執(zhí)行某些代碼塊的語句,提高了程序的執(zhí)行效率。Python的循環(huán)語句包括:while循環(huán)和for循環(huán)。
1、while循環(huán)
i = 1
while i < 6:
print(i)
i += 1
上面的代碼中,while循環(huán)語句使用了一個計數(shù)器變量i。只要i小于6,就繼續(xù)執(zhí)行循環(huán)內的代碼塊,輸出i的值。每次循環(huán)結束前,將i加1。
2、for循環(huán)
fruits = ["apple", "banana", "cherry"]
for x in fruits:
print(x)
上面的代碼中,for循環(huán)語句遍歷水果列表fruits,將列表中的每一個元素依次賦值給變量x,并輸出x的值。循環(huán)結束后,代碼執(zhí)行完畢。
三、優(yōu)化代碼邏輯控制
掌握條件語句和循環(huán)語句等邏輯結構后,我們可以利用這些結構實現(xiàn)代碼邏輯的優(yōu)化,提高代碼執(zhí)行效率和可讀性。
1、在循環(huán)內部使用條件語句
for i in range(10):
if i % 2 == 0:
print(i)
上面的代碼中,for循環(huán)遍歷10個數(shù)字,如果數(shù)字除以2的余數(shù)為0,則輸出該數(shù)字。通過在循環(huán)內部使用if語句,我們可以在執(zhí)行for循環(huán)的同時實現(xiàn)更加靈活的邏輯控制。
2、使用列表推導式
numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
even_numbers = [x for x in numbers if x % 2 == 0]
print(even_numbers)
上面的代碼中,我們使用列表推導式生成一個包含numbers列表中偶數(shù)的新列表even_numbers。列表推導式是一種簡化代碼邏輯的方式,可以快速生成新的列表、集合和字典。
3、使用函數(shù)
def is_prime(n):
if n < 2:
return False
for i in range(2, n):
if n % i == 0:
return False
return True
for i in range(100):
if is_prime(i):
print(i)
上面的代碼中,我們定義了一個名為is_prime(n)的函數(shù),用于判斷一個數(shù)是否為素數(shù),如果是,則返回True;否則返回False。在主程序中,我們使用for循環(huán)遍歷100個數(shù)字,并通過調用is_prime(n)函數(shù),輸出數(shù)字列表中的素數(shù)。
通過優(yōu)化代碼邏輯控制,我們可以大大提高程序的效率和可讀性,實現(xiàn)更加靈活復雜的邏輯操作。