亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

求大神解釋

http://img1.sycdn.imooc.com//5e47838500019ffe02540190.jpghttp://img1.sycdn.imooc.com//5e4783900001becd03310191.jpg

答案為什么會不一樣

正在回答

6 回答

不一樣的,圖二的 x<=100改成 x<100就一樣了

0 回復 有任何疑惑可以回復我~

我用的列表推導式

L = [(x * x) for x in range(1, 101)]


0 回復 有任何疑惑可以回復我~

當然是一樣的 第一圖代碼多了0*0 無效 還是等價于從1*1開始的

0 回復 有任何疑惑可以回復我~

代碼是一行一行的運行,第一個代碼是正確的先運行了append函數再x加一后判斷x<=100,如果成立,就接著運行,不成立就結束。第二段代碼,x=99時,append(100*100)就已經滿足要求,但是此時x=99,判斷x<=100,成立,就會在運行一次,x=100時,經x=x+1,后append(101*101),再判斷while ,x<=100,成立,結束。所以第二段代碼比第一段代碼要多一個101*101


0 回復 有任何疑惑可以回復我~

等會,說錯了,答案是一樣的


0 回復 有任何疑惑可以回復我~

由于變量X增加的順序不同,圖一是列表數據產生于變量更改之前,圖二列表數據產生于變量更改之后。兩個程序導致生成的列表第一個數據和最后一個數據不同

0 回復 有任何疑惑可以回復我~
#1

慕萊塢1109235 提問者

答案的確是不一樣的,可是我覺得圖二的第一次循環放進list中的是1*1啊
2020-02-15 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消
初識Python
  • 參與學習       758399    人
  • 解答問題       8967    個

學python入門視頻教程,讓你快速入門并能編寫簡單的Python程序

進入課程

求大神解釋

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號