數列 - 拼圖

Carolina Franco avatar
By Carolina Franco
at 2012-07-07T01:49

Table of Contents

※ 引述《EIORU ()》之銘言:
: 有一個正整數數列 規則如下 , 起始數字是 X , y*z=X , 且 y<=z
: 則第1個數字為 yz 並排
: 當數列的數字最接近但不足10000時結束
: 將最後一個數字 和 該數字是數列的第幾個 相乘 得出 S Q: 求S最大是多少
: Ex. 1,11,111,337,1337,7191,9799 end S = 9799 x 6 = 58794
: 0 1 2 3 4 5 6
: Ex. 2,12 -> (1)112 (2)26 (3)34 都可以
: (遇到多選時)

看到天使大的推文就想說這題有沒有可能光從條件就估計出最長的數列 (下簡稱鍊)

的上限。

先來看原題解答數列 (黑文於下, |表示把y z分開)

9|999 -> 8|991 -> 7|928 -> 6|496 -> 2|976 -> 19|52 ->
9|88 -> 7|92 -> 6|44 -> 2|64 -> 1|28 -> 2|8 -> 1|6 -> 6

看看趨勢,把每兩項的比寫出來是

1.11, 1.13, 1.22, 2.18, 1.52, 1.98, 1.25, 1.23, 2.44, 2.06, 4.57, 1.75, 2.67

如果順著算的話...鬼才知道第三步得選這個大飛躍的路走...

那倒著算呢,分支數極少、又不需要因數分解可以算很快吧

但是...例如說用紙筆算瘋狂的把9999~9900這一百個數中最長的那些鍊列舉出來

結果你只會找到 9999 (13步) 、9997 和 9992 (12步,12步的鍊還有25個QAQ)

更糟糕的是這一堆計算還是不能排除某個數98xx剛好有14步的鍊...


因此這題就只好就範圍內窮舉了(ie寫程式= =|||)

做法一樣有順著算(很慢)、倒著算(飛快)兩種



Mathematica碼: 傷眼注意 XD

(*空格為幫助閱讀,執行前全拿掉比較不會出錯*)
(*此為倒著算算法*)

Clear[LongestChain];
ID[x_Integer]:=IntegerDigits[x];
FD[x_List]:=FromDigits[x];

LongestChain[n_]:=
LongestChain[x]=
Module[{}, poss=Times@@@
Cases[
Table[
{FD[ID[n][[1;;i]], FD[ID[n][[i+1;;]]]},
{i,1,Quotient[Length@[ID@n],2]}
],
{a_Integer,b_Integer}/;a<=b
];
If[poss=={}, 0, 1 + Max@@(LongestChain/@poss)]
]

LongestChainTrace[n_]:=
LongestChainTrace[n]=
Module[{}, poss=Times@@@
Cases[
Table[
{FD[ID[n][[1;;i]], FD[ID[n][[i+1;;]]]},
{i,1,Quotient[Length@[ID@n],2]}
],
{a_Integer,b_Integer}/;a<=b
];
If[poss=={}, {n}, Prepend[LongestChainTrace[poss[[
Select[Ordering[LongestChain/@poss], #==1&,1][[1]]
]]],n]]
]

(*以100,000為例尋找*)
result = LongestChain/@ Range[100000];

(*列出前三長的chain開頭 (結尾) *)
show = Table[{Flatten@Position[result,Max[result]-i], Max[result]-i},{i,0,2}]

(*想看哪個鍊自行手動^^*)
LongestChainTrace[]


--
Tags: 拼圖

All Comments

Dorothy avatar
By Dorothy
at 2012-07-07T15:39
倒著算然後讓程式順著找會比較快
Edith avatar
By Edith
at 2012-07-11T10:30
像是9999前一個可以是9*999=8991也可以是99*99=9801
Jacob avatar
By Jacob
at 2012-07-12T06:31
就讓程式去看這兩個數字誰的鍊數比較大
Ida avatar
By Ida
at 2012-07-12T20:33
讓程式順著找的意思是先讓程式從1開始算每一個數字的最大鍊
Blanche avatar
By Blanche
at 2012-07-15T20:27
數,這樣很快可以找到8991對應的最大鍊數
Eartha avatar
By Eartha
at 2012-07-20T11:01
這題我該怎說呢...會給人種可以靠人解的假象 最後發現還
Agatha avatar
By Agatha
at 2012-07-24T03:48
是要靠程式窮舉ˊwˋ...

最佳排列

Christine avatar
By Christine
at 2012-07-06T18:24
最佳排列  ───────────────────────────────────────  規則  將0~9共十個數字依序排成一列,並 ┌───────────────┐      將相鄰的兩個數字結合,形成第二列 │ 2 3 0 4 9 7 8 5 1 6 │      數字,根據以下規則統計分數:    ...

四角拼圖 方向不規則箭頭版

Andrew avatar
By Andrew
at 2012-07-05T22:11
這裡有一副四角拼圖 http://g.udn.com.tw/upfiles/B_PU/puzzlez/PSN_PHOTO/988/f_8465988_1.PNG 仔細一看,可以看見每一小片的方向配置 均是不相同的(先不考慮箭頭的種類) 有空的人不妨解解看,這套四角拼圖做得還不錯。 如果你在一小時內做出來 ...

數列

Elma avatar
By Elma
at 2012-07-05T12:40
有一個正整數數列 規則如下 , 起始數字是 X , y*z=X , 且 yandlt;=z 則第1個數字為 yz 並排 當數列的數字最接近但不足10000時結束 將最後一個數字 和 該數字是數列的第幾個 相乘 得出 S Q: 求S最大是多少 Ex. 1,11,111,337,1337,7191,97 ...

1000片的拼圖

Regina avatar
By Regina
at 2012-07-05T08:30
朋友送了一副1000片的拼圖 然後我去買了木框 昨天拼好之後,用附贈的膠水上了膠(發現邊邊都沒上到) 經過一個晚上的陰乾 打算要把拼圖放進去的時候才發現!! 拼圖比框還大了一點點 請問各位我現在該怎麼辦,用剪刀或美工刀修掉多餘的部分嗎? -- - ...

ProjectEuler 391 Hopping Game

Odelette avatar
By Odelette
at 2012-07-01T12:15
391. Hopping Game http://projecteuler.net/problem=391 使 s_k 為將 0 到 k 的數字以二進制表示時 1 的數量。 舉例來說,將 0 到 5 以二進制表示時,我們得到 0, 1, 10, 11, 100, 101 一共有 7 個 1,故 s_ ...