Re: [問題] 使用遞迴輸出

看板Python作者 (逆道者)時間4年前 (2019/10/16 10:51), 4年前編輯推噓4(401)
留言5則, 2人參與, 4年前最新討論串2/4 (看更多)
其實這個用數學可以簡化迴圈結構 List2和List3的index分別是5進制和2進制 每進步一塊,List2就會+1 List2加到超過5^5,List3就會+1 (換大鈔的概念) 因此根據這個規律,在第n塊下 第i列List1的index,就是i 第i列List2的index,是把n除以5^i取商數後,再把商數除以5取餘數 第i列List3的index,是把n除以(5^5)取商數後,再把商數除以2^i取商數後,再把商數除 以2取餘數 於是可以得到以下程式碼 List1=["A","B","C"]#,"D","E"] List2=[1,2,3]#,4,5] List3=["X","Y"] for n in range(len(List2)**len(List1) * len(List3)**len(List1)): for i in range(len(List1)): i_L1=i i_L2=n // (len(List2)**i) % len(List2) i_L3=(n // len(List2)**len(List2)) // (len(List3)**i) % len(List3) print(List1[i_L1],List2[i_L2],List3[i_L3]) print() 其中我暫時截短了List的長度,這樣會比較快看到結果 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 61.216.6.171 (臺灣) ※ 文章網址: https://www.ptt.cc/bbs/Python/M.1571194308.A.4D1.html

10/16 13:05, 4年前 , 1F
您好,在原來List沒有被截短的情況下,您的 n = 2 * 3125
10/16 13:05, 1F

10/16 13:06, 4年前 , 2F
* 4 = 25000 這樣嗎?
10/16 13:06, 2F
應該是n= 5^5 * 2^5 才對 感謝提醒 ※ 編輯: papple23g (61.216.6.171 臺灣), 10/16/2019 13:33:41 ※ 編輯: papple23g (61.216.6.171 臺灣), 10/16/2019 13:34:56

10/16 13:35, 4年前 , 3F
我看原 po 給的輸出範例,n 應該等於 5^10
10/16 13:35, 3F

10/16 13:47, 4年前 , 4F
更正: 10^5 才對
10/16 13:47, 4F
剛剛有全部印出來確認了一下,確實是5^5 * 2^5沒錯 也就是(List2的長度)^(List1的位數)*(List3的長度)^(List1的位數) ※ 編輯: papple23g (61.216.6.171 臺灣), 10/16/2019 13:53:55

10/17 01:22, 4年前 , 5F
感謝
10/17 01:22, 5F
文章代碼(AID): #1TfeN4JH (Python)
文章代碼(AID): #1TfeN4JH (Python)