欧拉工程第68题:Magic 5-gon ring

任意一条线上的三个数的和都等于9,顺时针,从最小的外圈开始,得到的序列是:432621213
和 序列

9位的字符串;三角环所能形成的最大字符串为432621513。

使用数字1到10,通过不同的安排,可以得到16位或17位的字符串。五角环所能形成的最大的16位的字符串是什么?
16位的字符,10在外圈
17位的字符,10在内圈
求最大的字符串
6,7,8,9,10应该在外圈,1,2,3,4,5在内圈
2*(1+2+3+4+5) +6+7+8+9+10 = 70,每三个数的和是14
下面其实可以手工做出来了
以外圈最小的数开始:6,在1-5找出两个数使得这三个数的和是14只有5,3,最大数,5要在中间

外圈数还剩:7,8,9,10,内圈数还剩:1,2,4.在3所在的线上还差11,只有10+1=11

外圈数还剩:7,8,9,内圈数还剩:2,4.在1所在的线上还差13,只有9+4=11

外圈数还剩:7,8,内圈数还剩:2
下面就是这样的了

答案就是:6531031914842725
下面用Python暴露破解
导入产生排列的包
from itertools import permutations
下面你该知道怎么做了吧
遍历所有的排列,选择满足上面条件的数
全部程序 :
from itertools import permutations import time as time def run():
digits=['1','2','3','4','5','6','7','8','9','10']
perm = permutations(digits)
res = 0
for p in perm:
arr = map(int,p)
candidate = p[0] + p[1] + p[2] +\
p[3] + p[2] + p[4]+\
p[5] + p[4] + p[6]+\
p[7] + p[6] + p[8]+\
p[9] + p[8] + p[1];
# print candidate
if arr[0] > arr[3] or arr[0]> arr[5] or arr[0] > arr[7] or arr[0]> arr[9]:continue
if arr[1]==10 or arr[2]==10 or arr[4]==10 or arr[8] ==10 :continue
if (arr[0]+arr[1]+arr[2]) != (arr[3] + arr[2] + arr[4]) :continue
if (arr[0]+arr[1]+arr[2]) != (arr[5] + arr[4] + arr[6]) :continue
if (arr[0]+arr[1]+arr[2]) != (arr[7] + arr[6] + arr[8]) :continue
if (arr[0]+arr[1]+arr[2]) != (arr[9] + arr[8] + arr[1]) :continue
if int(candidate)>res and len(candidate)==16:
res = int(candidate)
# print res ,arr print res if __name__ == '__main__':
start = time.time()
run()
print "running time:",(time.time() - start),'s'
结果
6531031914842725
running time: 30.3180000782 s
这个时间真是太长了。
package project61;
public class P68{
int[] p = {1,2,3,4,5,6,7,8,9,10};
void run(){
for(int i=1;i<20;i++){
GetNextPerm();
System.out.println(""+p[0]+p[1]+p[2]+p[3]+p[4]+p[5]+p[6]+p[7]+p[8]+p[9]);
}
String result="";
while(true){
if(!GetNextPerm()) break;
if(CheckResult()){
String candidate ="" + p[0] + p[1] + p[2]
+ p[3] + p[2] + p[4]
+ p[5] + p[4] + p[6]
+ p[7] + p[6] + p[8]
+ p[9] + p[8] + p[1];
System.out.println(candidate);
}
}
}
// 类似于快速排序
boolean GetNextPerm(){
int N = p.length;
int i= N -1;
while(p[i-1]>=p[i]){
i--;
if(i<1) return false;
}
int j = N;
while(p[j-1]<=p[i-1]){
j = j-1;
}
swap(i-1,j-1);
i++;
j=N;
while(i<j){
swap(i-1,j-1);
i++;
j--;
}
return true;
}
boolean CheckResult(){
if(p[1]==10||
p[2]==10||
p[4]==10||
p[8]==10) return false;
if(p[0] > p[3]||
p[0] > p[5]||
p[0] > p[7]||
p[0] > p[9]) return false;
if(p[0] + p[1]+ p[2] != p[3] + p[2] +p[4]) return false;
if(p[0] + p[1]+ p[2] != p[5] + p[4] +p[6]) return false;
if(p[0] + p[1]+ p[2] != p[7] + p[6] +p[8]) return false;
if(p[0] + p[1]+ p[2] != p[9] + p[8] +p[1]) return false;
return true;
}
void swap(int i,int j){
int k=p[i];
p[i] = p[j];
p[j] = k;
}
public static void main(String[] args){
long t0 = System.currentTimeMillis();
new P68().run();
long t1 = System.currentTimeMillis();
System.out.println("running time:"+(t1 - t0)+"ms");
}
}
这个自己参数所以的排列,再找满足条件的数
程序跑的倒是很快
6531031914842725
running time:77ms
欧拉工程第68题:Magic 5-gon ring的更多相关文章
- 欧拉工程第69题:Totient maximum
题目链接 欧拉函数φ(n)(有时也叫做phi函数)可以用来计算小于n 的数字中与n互质的数字的个数. 当n小于1,000,000时候,n/φ(n)最大值时候的n. 欧拉函数维基百科链接 这里的是p是n ...
- 欧拉工程第70题:Totient permutation
题目链接 和上面几题差不多的 Euler's Totient function, φ(n) [sometimes called the phi function]:小于等于n的数并且和n是互质的数的个 ...
- 欧拉工程第67题:Maximum path sum II
By starting at the top of the triangle below and moving to adjacent numbers on the row below, the ma ...
- 欧拉工程第66题:Diophantine equation
题目链接 脑补知识:佩尔方差 上面说的貌似很明白,最小的i,对应最小的解 然而我理解成,一个循环的解了,然后就是搞不对,后来,仔细看+手工推导发现了问题.i从0开始变量,知道第一个满足等式的解就是最小 ...
- 欧拉工程第65题:Convergents of e
题目链接 现在做这个题目真是千万只草泥马在心中路过 这个与上面一题差不多 这个题目是求e的第100个分数表达式中分子的各位数之和 What is most surprising is that the ...
- 欧拉工程第56题:Powerful digit sum
题目链接 Java程序 package projecteuler51to60; import java.math.BigInteger; import java.util.Iterator; im ...
- 欧拉工程第55题:Lychrel numbers
package projecteuler51to60; import java.math.BigInteger; import java.util.Iterator; import java.util ...
- 欧拉工程第54题:Poker hands
package projecteuler51to60; import java.awt.peer.SystemTrayPeer; import java.io.BufferedReader; impo ...
- 欧拉工程第53题:Combinatoric selections
package projecteuler51to60; class p53{ void solve1(){ int count=0; int Max=1000000; int[][] table=ne ...
随机推荐
- [大牛翻译系列]Hadoop(22)附录D.2 复制连接框架
附录D.2 复制连接框架 复制连接是map端连接,得名于它的具体实现:连接中最小的数据集将会被复制到所有的map主机节点.复制连接的实现非常直接明了.更具体的内容可以参考Chunk Lam的<H ...
- 通过Linux命令过滤出binlog中完整的SQL语句
DB:5.6.16CentOS:CentOS release 6.3 (Final) 当insert语句通过空格跨行输入的时候,如何提取完整的insert语句! 创建一个空表:mysql> cr ...
- 使用WinSetupFromUSB来U盘安装WINDOWS2003
今天用UltraISO制作WINDOWS2003的U盘的安装启动,在安装系统的时候发现错误提示“INF file txtsetup.sif is corrupt or missing .status ...
- Entity Framework Power Tools安装和使用
Entity Framework Power Tools是一个由EntityFramework开发小组提供的工具,它可以从现有数据库生成Fluent款式的Code First代码. 大致来说,这个工具 ...
- 小兵眼中的Java Struts2
老魏终于可以回园子了,但是这次要慢慢的回来,不能一下子回来,这段时间除了要照顾刚出生的小女儿,还要做项目.说实在的老魏时间真是有限,不能照顾到园子的文章了,所以只能慢慢的回来写文章了.抱歉! ...
- 第二章 Spring MVC入门
2.1.Spring Web MVC是什么 Spring Web MVC是一种基于Java的实现了Web MVC设计模式的请求驱动类型的轻量级Web框架,即使用了MVC架构模式的思想,将web层进行职 ...
- php文字水印和php图片水印实现代码(二种加水印方法)
文字水印 文字水印就是在图片上加上文字,主要使用gd库的imagefttext方法,并且需要字体文件.效果图如下: $dst_path = 'dst.jpg';//创建图片的实例$dst = imag ...
- Notes of the scrum meeting(10/31)
meeting time:3:00~4:30p.m.,October 30th,2013 meeting place:绿园 attendees: 顾育豪 ...
- 学习KnockOut第一篇之Hello World
学习KnockOut第一篇之Hello World 笔者刚开始学习KnockOut.写的内容就相当于一个学习笔记.且在此处向官网致敬,比较喜欢他们家的Live Example版块,里面有jsFiddl ...
- redis window环境下的安装地址
https://github-cloud.s3.amazonaws.com/releases/3402186/25358446-c083-11e5-89cb-61582694855e.zip?X-Am ...