鱼C论坛

 找回密码
 立即注册
查看: 3704|回复: 7

题目68:一个“魔术”五角环所能形成的最大的16位字符串是什么?

[复制链接]
发表于 2015-10-14 16:21:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
Magic 5-gon ring

Consider the following "magic" 3-gon ring, filled with the numbers 1 to 6, and each line adding to nine.

QQ20151014-1@2x.png

Working clockwise, and starting from the group of three with the numerically lowest external node (4,3,2 in this example), each solution can be described uniquely. For example, the above solution can be described by the set: 4,3,2; 6,2,1; 5,1,3.

It is possible to complete the ring with four different totals: 9, 10, 11, and 12. There are eight solutions in total.

Total        Solution Set
9        4,2,3; 5,3,1; 6,1,2
9        4,3,2; 6,2,1; 5,1,3
10        2,3,5; 4,5,1; 6,1,3
10        2,5,3; 6,3,1; 4,1,5
11        1,4,6; 3,6,2; 5,2,4
11        1,6,4; 5,4,2; 3,2,6
12        1,5,6; 2,6,4; 3,4,5
12        1,6,5; 3,5,4; 2,4,6
By concatenating each group it is possible to form 9-digit strings; the maximum string for a 3-gon ring is 432621513.

Using the numbers 1 to 10, and depending on arrangements, it is possible to form 16- and 17-digit strings. What is the maximum 16-digit string for a "magic" 5-gon ring?

QQ20151014-2@2x.png

题目:

考虑如下的“魔术”三角环:该环被1到6的数字填充,并且每一行的和为 9。

QQ20151014-1@2x.png

按照顺时针顺序,从外部节点最小的三个为一组的组开始(该例中为4,3,2),每一组解都可以被唯一描述。例如,上图所示的解可以被描述为集合: 4,3,2; 6,2,1; 5,1,3。

这个环还可以被用四个不同的和来完成。一共有八组解

和                   解
9          4,2,3; 5,3,1; 6,1,2
9          4,3,2; 6,2,1; 5,1,3
10        2,3,5; 4,5,1; 6,1,3
10        2,5,3; 6,3,1; 4,1,5
11        1,4,6; 3,6,2; 5,2,4
11        1,6,4; 5,4,2; 3,2,6
12        1,5,6; 2,6,4; 3,4,5
12        1,6,5; 3,5,4; 2,4,6

将每组解的数字连接起来,可以得到一个 9 位的字符串;三角环所能形成的最大字符串为 432621513。

使用数字 1 到 10,通过不同的安排,可以得到 16 位或 17 位的字符串。五角环所能形成的最大的 16 位的字符串是什么?

QQ20151014-2@2x.png

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-12-24 22:27:06 | 显示全部楼层
本帖最后由 jerryxjr1220 于 2017-10-12 10:26 编辑

这题其实挺简单的,无非就是排列组合问题,10个空格填上1~10个数字,由于是取16位数字中最大的,所以10一定是在外圈,在内圈的话就是17位数字了。
代码:
from itertools import permutations as pt 
maxi = 0
for each in pt(range(1,11)):
        if 10 in each[5:]: continue
        if each[0]+each[5]+each[6]==each[1]+each[6]+each[7]==each[2]+each[7]+each[8]==each[3]+each[8]+each[9]==each[4]+each[9]+each[5]:
                s=''.join([str(each[0])+str(each[5])+str(each[6])+str(each[1])+str(each[6])+str(each[7])+str(each[2])+str(each[7])+str(each[8])+str(each[3])+str(each[8])+str(each[9])+str(each[4])+str(each[9])+str(each[5])])
                if len(s)==16 and each[0]==min(each[0:5]):
                        maxi = max(maxi,int(s))
print(maxi)

输出:
6531031914842725
[Finished in 1.7s]

原本以为会用很长时间,结果才1.7秒就出结果了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-9-9 21:04:27 | 显示全部楼层
#Using the numbers 1 to 10, and depending on arrangements, 
#it is possible to form 16- and 17-digit strings. 
#What is the maximum 16-digit string for a “magic” 5-gon ring?
'''
1+2+...10=55, inner five digits min is 12345=15, max is 678910=40
so average sum of three digit is 14(55+15) to 19(55+40)
16-digit,so 10 is in outer five digit
inner max is 35, average sum of 3digit is (55+35)/5=18
'''
import itertools,time

def checkThreeGonRing(rings):
        r = []
        for three in rings:
                r.extend(three)
        r = sorted(set(r))
        return r == list(range(1,11))

def to16digitstring(rings):
        r = ''
        for three in rings:
                for i in three:
                        r += str(i)                
        return int(r)

def getmax16digit():
        maxstr = 0
        for inner5 in itertools.permutations(list(range(1,10)), 5):
                average5 = (55+sum(inner5)) // 5
                threeGonRing = []
                for i in range(5):
                        outerdigit = average5 - inner5[i] - inner5[(i+1)%5]
                        threeGonRing.append((outerdigit, inner5[i], inner5[(i+1)%5]))
                if not checkThreeGonRing(threeGonRing):
                        continue
                outerDs = [x[0] for x in threeGonRing]
                lowestindex = outerDs.index(min(outerDs))
                if lowestindex != 0:
                        threeGonRing = threeGonRing[lowestindex:] + threeGonRing[:lowestindex]
                #threeGonRing.sort(key= lambda x : x[0]) #incorrect
                s = to16digitstring(threeGonRing)
                if s > maxstr:
                        maxstr = s

        return maxstr

st = time.time()
print(getmax16digit()) #6531031914842725
print('cost {0}s'.format(time.time()-st)) #0.09700536727905273s
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-10-5 19:24:02 | 显示全部楼层
不需要用编程,结果是
6531031914842725
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-7-30 10:55:10 | 显示全部楼层
'分析:按题意,要从最外侧结点所填的数最小的线开始,可知外圈最小为6,且外圈五数必为6,7,8,9,10(可反证)
'因此,内圈为1,2,3,4,5。每条线数字之和为(2*内圈和+外圈和)/5=14
'进一步分析:第一条线第一个数为6,另两数之和即为8,考察(1,2,3,4,5),只能是3+5=8。因为取大数,所以第一条线为6-5-3
'在此基础上暴搜即可。按顺序针次序为每一节点编号:(6-5-3)-(w1-3-n1)-(w2-n1-n2)-(w3-n2-n3)-(w4-n3-5),其中外圈w=7 to 10,内圈n为1,2,4
'''
def euler068():                                            
    import itertools
    s=14   
    for (w1,w2,w3,w4) in itertools.permutations([7,8,9,10],4):   #外圈
        for (n1,n2,n3) in itertools.permutations([1,2,4],3):    #内圈
            if w1 + 3 + n1 == w2 + n1 + n2 == w3 + n2 + n3 == w4 + n3 + 5 == s:
                return("653%d%d%d%d%d%d%d%d%d%d%d%d"%(w1,3,n1,w2,n1,n2,w3,n2,n3,w4,n3,5))

print(euler068())
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-7-22 14:49:05 | 显示全部楼层
有小学奥数题内味儿了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-1-10 21:59:21 | 显示全部楼层
本帖最后由 guosl 于 2022-1-10 22:09 编辑

穷举死做也很快
/*
答案:6531031914842725
耗时:0.0150001秒
*/
#include <iostream>
#include <algorithm>
#include <string>
using namespace std;

const int nSteps = 10;

int main(void)
{
  int a[10] = { 1,2,3,4,5,6,7,8,9,10 };
  long long nMax = 0;
  do
  {
    if (a[0] > a[1] || a[0] > a[2] || a[0] > a[3] || a[0] > a[4])
      continue;
    int nS[5];
    nS[0] = a[0] + a[5] + a[6];
    nS[1] = a[1] + a[6] + a[7];
    nS[2] = a[2] + a[7] + a[8];
    nS[3] = a[3] + a[8] + a[9];
    nS[4] = a[4] + a[9] + a[5];
    if (nS[0] == nS[1] && nS[0] == nS[2] && nS[0] == nS[3] && nS[0] == nS[4])
    {
      string str = "";
      str += (a[0] < 10) ? string(1, char(a[0] + 48)) : string("10");
      str += (a[5] < 10) ? string(1, char(a[5] + 48)) : string("10");
      str += (a[6] < 10) ? string(1, char(a[6] + 48)) : string("10");
      str += (a[1] < 10) ? string(1, char(a[1] + 48)) : string("10");
      str += (a[6] < 10) ? string(1, char(a[6] + 48)) : string("10");
      str += (a[7] < 10) ? string(1, char(a[7] + 48)) : string("10");
      str += (a[2] < 10) ? string(1, char(a[2] + 48)) : string("10");
      str += (a[7] < 10) ? string(1, char(a[7] + 48)) : string("10");
      str += (a[8] < 10) ? string(1, char(a[8] + 48)) : string("10");
      str += (a[3] < 10) ? string(1, char(a[3] + 48)) : string("10");
      str += (a[8] < 10) ? string(1, char(a[8] + 48)) : string("10");
      str += (a[9] < 10) ? string(1, char(a[9] + 48)) : string("10");
      str += (a[4] < 10) ? string(1, char(a[4] + 48)) : string("10");
      str += (a[9] < 10) ? string(1, char(a[9] + 48)) : string("10");
      str += (a[5] < 10) ? string(1, char(a[5] + 48)) : string("10");
      if (str.length() == 16)
      {
        long long nTemp = atoll(str.c_str());
        nMax = max(nMax, nTemp);
      }
    }
  }
  while(next_permutation(a, a + 10));
  cout << nMax << endl;
  return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-2-28 14:48:02 | 显示全部楼层
6531031914842725
Time:0.0s
import time
st=time.time()
# 中间会出现两次,外围出现一次,16位意味着10出现在外围。
# 为了使数字尽可能地大,最高位尽可能大,外围最小值也要尽可能的大,所以一半以上的数字在外围,一半以下的在内圈
n=5
# 内圈计算两次,加上外围数字,除以n就知道和为多少了
num=(1+2*n)+(1+n)//2
l=list(range(1,n+1))
ans=''
ans=ans+str(n+1)
ans=ans+str(n)
ans=ans+str((1+n)//2)
a=(1+n)//2
# 后面不出错,应该需要数学证明。理论上不难
for i in range(2*n,n+1,-1):
    ans=ans+str(i)
    ans=ans+str(a)
    a=num-i-a
    ans=ans+str(a)
print(ans)
print('Time:{}s'.format(time.time()-st))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-22 21:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表