puzzle 板


LINE

※ 引述《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[] --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 36.236.119.215
1F:→ newacc:倒着算然後让程式顺着找会比较快07/07 10:56
2F:→ newacc:像是9999前一个可以是9*999=8991也可以是99*99=9801 07/07 10:56
3F:→ newacc:就让程式去看这两个数字谁的链数比较大07/07 10:57
4F:→ newacc:让程式顺着找的意思是先让程式从1开始算每一个数字的最大链 07/07 10:57
5F:→ newacc:数,这样很快可以找到8991对应的最大链数 07/07 10:58
※ 编辑: jurian0101 来自: 36.236.116.115 (07/07 14:50)
6F:推 DreamYeh:这题我该怎说呢...会给人种可以靠人解的假象 最後发现还 07/09 11:47
7F:→ DreamYeh:是要靠程式穷举ˊwˋ... 07/09 11:48







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灯, 水草

请输入看板名称,例如:Gossiping站内搜寻

TOP