Programming 板


LINE

首先畫個圖: 9 8 7 6 5 4 3 2 1 1234567 位數 假設數值為2545397。 9 x 8 7 x 6 5 x x 4 x 3 x 2x 1 1234567 很容易可以看到,重要的是建立四個遞增點,剩下的點只要在前一個遞增點以下 就不會影響結果: 9 x 8 - 7 - 6 - 5 x x - 4 - - - 3 - - - 2x - - - 1 - - - 1234567 那麼四個遞增點怎麼建立呢?四層迴圈硬跑基本上寫得正確就不會跑出不可能的 狀態,也就是後數比前數大或相等即可(以Python為例,注意range(a, b)表示包含a 到(b-1)): sum = 0 n_list = [0] * 4 for n_list[0] in range(0, 10): for n_list[1] in range(n_list[0], 10): for n_list[2] in range(n_list[1], 10): for n_list[3] in range(n_list[2], 10): sum += poss_num(n_list) 每建立一套遞增點,例如2559,那麼我們就要插入剩下三個數並確保三個數不會 影響遞增點數量。 首先觀察2前面不能插值,因為2前面<= 2會使遞增點多一,> 2會使2不再是遞增 點。 再來,如果我們要插在2跟5之間,合法值有幾個?答案是0、1,也就是< 2的兩 個數。同理,插在5跟5之間只要看前面的5而可以接受0~4,5跟9之間也是看5而同樣 是0~4,9之後則是0~8。也就是說,很巧地,你要插一個值到x這個值後面,就有x這 麼多種不重複的可能性。 我們驗證一下極端值0是不是也符合?0369為例,0後面可以插值而不影響遞增數 量或位置嗎?看來是不行的,插個0或以上就變成遞增五個數了,所以0後面插值的可 能性確實是0種。 那麼同樣2559為例,如果我們要插2個值在2後面,1個在9後面,有幾種可能? 2005590 2005591 2005592 . . 2005598 2015590 . . 2115598 接在2後面的值有2種可能,9後面就有9種可能,所以是2*2*9 = 36。也就是說, 我們甚至都不用列出來,直接可以簡單乘法就算出這邊的可能性。 那麼同樣跑完全沒有多餘的迴圈來決定三個數「依序」插在哪裡,就可以個別用 上述公式解算出各種插入位置的可能性。第一個數可以有四個位置選擇(四個遞增點 之後),第二個數必須在第一個數同樣或更後面的位置,以此類推。最後就可以加總 : def poss_num(n_list): sum = 0 pos_list = [0] * 3 for pos_list[0] in range(0, 4): for pos_list[1] in range(pos_list[0], 4): for pos_list[2] in range(pos_list[1], 4): sum += ( n_list[pos_list[0]] * n_list[pos_list[1]] * n_list[pos_list[2]] ) return sum 總結一下,關鍵就在於兩個點: 1. 選取數字時的迴圈怎麼樣徹底避開不可能狀況 -> 兩者都是遞增 2. 遞增四個數字以及插入位置確定後,如何避免一一窮舉 -> 注意到內層有公式解 注意Python完整Code要把poss_num()的定義搬到主迴圈前面去。執行時間基本上 按下去就出來了。 有心的話可以將兩個多層迴圈都改寫為stack,這樣你就可以處理此問題的通解 :任意位數,任意遞增長度。 -- 「傳說的最後,魔王總是被勇者封印。但勇者會逝去、封印會衰弱,魔王卻永遠 不滅。傳說呢?傳說持續著。只是,變質了。所以對於傳說而言,只有反覆無常的自 己是主角,而魔王只是配角。勇者?勇者不過是消耗品罷了,封印則什麼也不是。妳 好不容易有機會當上配角,怎麼走回頭路想成為消耗品?妳早晚會什麼也不是的。」 --星.幻.夢的傳說 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 114.32.17.60 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Programming/M.1598937076.A.A19.html ※ 編輯: ddavid (114.32.17.60 臺灣), 09/01/2020 13:14:25
1F:推 SocketAM2: 試了一下,時間差不多(有點出乎意料)140.109.189.166 09/01 14:46
還好,你的改良版cut方式夠好,該砍的都有砍掉的話,大概就只多一些量不大 的邏輯判斷成本吧。
2F:→ SocketAM2: 但你的方法空間應該好不少140.109.189.166 09/01 14:47
※ 編輯: ddavid (114.32.17.60 臺灣), 09/01/2020 14:53:04
3F:推 SocketAM2: 檢查了一下,我的查表中只有165個項目140.109.189.166 09/01 15:05
4F:→ SocketAM2: 而且只被查了175次140.109.189.166 09/01 15:05
5F:→ SocketAM2: 效率出乎意料的好140.109.189.166 09/01 15:06
6F:推 applebeing: 感謝s大跟d大兩位的分享。線上測驗的 27.121.223.216 09/01 19:01
7F:→ applebeing: 解題時間大概十分鐘,加上緊張越想越 27.121.223.216 09/01 19:01
8F:→ applebeing: 打結。從兩位的解題思維學到很多! 27.121.223.216 09/01 19:01
※ 編輯: ddavid (1.164.183.14 臺灣), 11/21/2020 02:01:20







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:BuyTogether站內搜尋

TOP