第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

通過(guò)python函數(shù)制作“折疊列表”

通過(guò)python函數(shù)制作“折疊列表”

GCT1015 2023-10-18 16:16:12
這是我第三次嘗試解決這個(gè)問(wèn)題,作為一個(gè)全新的 python 用戶,我真的不明白我的教授想說(shuō)什么。我需要在 python 中創(chuàng)建一個(gè)函數(shù),它接受一個(gè)列表并將其“對(duì)半”,以便第一個(gè)和最后一個(gè)術(shù)語(yǔ)加在一起,第二個(gè)術(shù)語(yǔ)和倒數(shù)第二個(gè)術(shù)語(yǔ)等。如果我有一個(gè)空白列表,則輸出應(yīng)該為空,如果我有一個(gè)奇數(shù)列表,則不應(yīng)將中間項(xiàng)添加到任何內(nèi)容中。(教授的原始提示:提示:創(chuàng)建一個(gè)函數(shù),將列表作為輸入,并生成一個(gè)“對(duì)折”列表,我的意思是輸出中的第一項(xiàng)是輸入的第一項(xiàng)和最后一項(xiàng)的總和;輸出中的第二項(xiàng)是第二項(xiàng)和倒數(shù)第二項(xiàng)的總和,依此類推。因此,輸入 [10,2,3,1] 將產(chǎn)生 [11,5],而輸入 [10,2] ,3] 將產(chǎn)生 [13,2]。如果輸入是空列表,則應(yīng)返回空列表;如果輸入是 [5],則輸出應(yīng)為 [5]。)從其他人的幫助指導(dǎo),這就是我到目前為止所擁有的a = [10, 14, 21, 25, 52, 55]def folded_list(input_list):    a = input_list    folded_list_output = [ a[i] + a[-(i + 1) ] for i in range( len(a) // 2)]    return folded_list_outputprint(folded_list(a))我認(rèn)為這就是我的教授想要的。然而,他說(shuō): 你有一個(gè)代碼片段,也許可以做你想做的事情(使用一個(gè)奇特的“列表理解”,這就是所謂的方括號(hào)結(jié)構(gòu),而不是 for 循環(huán)),你只需要把它放在一個(gè)函數(shù)定義并測(cè)試它是否有效。列表理解的使用并不是它不是函數(shù)的原因,而是因?yàn)?def function_name(arguments): 看不到任何線條。測(cè)試“極端情況”總是一個(gè)好主意:例如,當(dāng)您提供空列表作為輸入時(shí),它是否會(huì)執(zhí)行您想要的操作?對(duì)于具有奇數(shù)個(gè)元素的列表會(huì)發(fā)生什么?(提示:它沒(méi)有做它應(yīng)該做的事情,因?yàn)橹虚g的元素完全被刪除了。)我真的不明白他想說(shuō)什么——我以為我的def folded_list(input_list):   a = input_list   folded_list_output = [ a[i] + a[-(i + 1) ] for i in range( len(a) // 2)]   return folded_list_output正是他在論證部分尋找的內(nèi)容。有誰(shuí)明白他的意思以及我應(yīng)該在代碼中嘗試修復(fù)什么?
查看完整描述

3 回答

?
慕妹3146593

TA貢獻(xiàn)1820條經(jīng)驗(yàn) 獲得超9個(gè)贊

只是為了好玩,我想嘗試使用zip、列表理解和切片表示法。就我個(gè)人而言,這更符合邏輯——但也許這只是我不平衡的大腦。


它看起來(lái)像這樣一團(tuán)糟:


def folded(lst) -> list:

    """Fold a list by summing opposite ends."""

    r = [a+b for a, b in zip(lst, lst[::-1])][:(len(lst)//2)+1]

    if len(lst) % 2 != 0:

        r = r[:-1] + [r[-1:][0]//2]

    else:

        r = r[:-1]

    return r

輸出:


l = [2]

>>> [2]


l = [2, 5]

>>> [7]


l = [2, 5, 8]

>>> [10, 5]


l = [2, 5, 8, 10]

>>> [12, 13]


l = [2, 5, 8, 10, 12]

>>> [14, 15, 8]


查看完整回答
反對(duì) 回復(fù) 2023-10-18
?
慕虎7371278

TA貢獻(xiàn)1802條經(jīng)驗(yàn) 獲得超4個(gè)贊

您有一個(gè)代碼片段,也許可以實(shí)現(xiàn)您想要的功能

您可能只向您的教授發(fā)送了列表理解。他們希望你發(fā)送一個(gè)函數(shù)

(使用奇特的“列表理解”,這就是所謂的方括號(hào)結(jié)構(gòu),而不是 for 循環(huán)),

非常不言自明

您只需將它放在函數(shù)定義中并測(cè)試它是否有效。列表理解的使用并不是它不是函數(shù)的原因,而是因?yàn)?nbsp;def function_name(arguments): 看不到任何線條。

def function_name(argument1, argument2, ...):是什么使該塊內(nèi)的代碼成為一個(gè)函數(shù)。如果您提交此信息:

def folded_list(input_list):
   a = input_list
   folded_list_output = [ a[i] + a[-(i + 1) ] for i in range( len(a) // 2)]  
    return folded_list_output

thenfolded_list是采用單個(gè)參數(shù)的函數(shù)input_list

由于您有一些 FORTRAN 背景,F(xiàn)ORTRAN 中的子例程或函數(shù)將被歸類為 Python 中的函數(shù)。還記得在 FORTRAN 中如何function myfunc(arg1, arg2, arg3) result(answer)定義函數(shù)嗎?你需要def myfunc(arg1, arg2, arg3)用Python說(shuō)。在 FORTRAN 中,函數(shù)必須返回某些內(nèi)容,但子例程不能。在 Python 中,函數(shù)可能返回某些內(nèi)容,也可能不返回某些內(nèi)容。這幾乎是新手級(jí)別的唯一區(qū)別。

測(cè)試“極端情況”總是一個(gè)好主意

極端情況是您期望會(huì)破壞代碼的情況(但理想情況下不會(huì))。測(cè)試極端情況可以確保您的代碼穩(wěn)健,并且在收到時(shí)髦但有效的輸入時(shí)不會(huì)中斷。

例如,當(dāng)您提供空列表作為輸入時(shí),它會(huì)執(zhí)行您想要的操作嗎?

可以?

folded_list([])
# Output: []

當(dāng)然看起來(lái)像它

對(duì)于具有奇數(shù)個(gè)元素的列表會(huì)發(fā)生什么?(提示:它沒(méi)有做它應(yīng)該做的事情,因?yàn)橹虚g的元素完全被刪除了。)

folded_list([1, 2, 3, 4, 5])
# Output: [6, 6]

嘿!這看起來(lái)不對(duì)勁!3列表中間的發(fā)生了什么?


現(xiàn)在,由于本練習(xí)的全部目的是讓您學(xué)習(xí),因此我不會(huì)向您提供所需的代碼。不過(guò),您可以使用以下算法:

  • 對(duì)于包含奇數(shù)個(gè)元素的列表,假設(shè)為 5,len(list) = 5

  • 所以len(list) // 2 = 2

  • 索引0和1需要添加到3和4上

  • 索引 2 需要單獨(dú)保留(嘿,看,2 = len(list) // 2

  • 迭代列表的前半部分

    • 如果當(dāng)前索引小于len(list)//2,則追加list[index] + list[-index]到新列表(負(fù)索引只是告訴 Python 向后計(jì)數(shù)而不是向前計(jì)數(shù)該元素,因此list[-2]將為您提供倒數(shù)第二個(gè)元素)

    • 如果索引等于len(list)//2,則追加list[index]

len(list)當(dāng)偶數(shù)時(shí)這有效嗎?如果它不適用于偶數(shù)大小的列表,您能想出一種適用于偶數(shù)奇數(shù)大小的列表的算法嗎?if或者是有條件檢查列表大小,然后針對(duì)偶數(shù)大小運(yùn)行一種算法,針對(duì)奇數(shù)大小運(yùn)行另一種算法的唯一選擇?這對(duì)你來(lái)說(shuō)是一個(gè)練習(xí)!

另請(qǐng)注意:當(dāng)我還是初學(xué)者時(shí),我發(fā)現(xiàn)首先寫(xiě)出整個(gè)循環(huán),然后如果可能的話將其壓縮為列表理解更為直觀。這個(gè)列表的理解:

folded_list_output = [ a[i] + a[-(i + 1) ] for i in range( len(a) // 2)]

如果這樣寫(xiě),就更容易理解(或者至少對(duì)我來(lái)說(shuō)是很多年前):

folded_list_output = []

for i in range(len(a) // 2):

    elem1 = a[i]

    elem2 = a[-(i + 1)] 


    folded_list_output.append(elem1 + elem2)


查看完整回答
反對(duì) 回復(fù) 2023-10-18
?
瀟瀟雨雨

TA貢獻(xiàn)1833條經(jīng)驗(yàn) 獲得超4個(gè)贊

您可以從 start(假設(shè)i)開(kāi)始迭代到中間并添加i兩側(cè)的 th 元素,然后返回新列表:


a = [10, 14, 21, 25, 52, 55]

b = [10, 14, 21, 25, 52, 55, 1]



def folded_list(input_list):

    new_list = []

    l = len(input_list)

    for i in range(l//2):

        new_list.append(input_list[i] + input_list[-i-1])


    if l % 2 != 0:

        return new_list + [input_list[l//2]]

    return new_list



print(folded_list(a))  # [65, 66, 46]

print(folded_list(b))  # [11, 69, 73, 25]


查看完整回答
反對(duì) 回復(fù) 2023-10-18
  • 3 回答
  • 0 關(guān)注
  • 255 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)