题目链接

找出最小的立方数,它的各位数的排列能够形成五个立方数

解决关键点:

这五个数的由相同的数组成的

可以用HashMap,Key是由各位数字形成的key,value记录由这几个数组成的立方数出现的次数

Key如何确定?

1.这个数的每位数排序后,(升序或降序),重新组成的数当作Key

2.根据该数0-9,出现的次数,组成的字符串当作Key

Java程序:

package project61;

import java.util.HashMap;

public class P62{
long getKey(int[] digits){
// 这里的映射是改变原来数的顺序
// 映射后的数低位到高位的数字越来越大
// digits数组中的数是原数对应位置出现了几次
// 可以直接将digits中的数链接起来
long key = 0;
for(int i=9;i>=0;i--){
while(digits[i]!=0){
key = key*10+i;
digits[i]--;
}
}
return key;
} void run(){
long a = 0;
long tempa = 0;
HashMap<Long, Integer> hm = new HashMap<Long, Integer>();
for (long i =10000;i>111;i--){
a = i*i*i;
tempa = a ;
int[] b = new int[10];
long key=0;
while(a!=0){
b[(int) (a%10)] +=1 ;
a=a/10;
}
key = getKey(b);
int value = hm.get(key)==null?1:(Integer)hm.get(key)+1;
if(value==5){
System.out.println(tempa);
}
hm.put(key, value); } }
String getKey1(int [] digits){
// 这里只是简单的把从高位到低位链接起来
String str="";
for(int i=9;i>=0;i--)
str+=digits[i]+"";
return str;
}
void run1(){
long a = 0;
long tempa = 0;
HashMap<String, Integer> hm = new HashMap<String, Integer>();
long i = 10000;
while(i>100){
a = i*i*i;
tempa = a ;
int[] b = new int[10];
String key;
while(a!=0){
b[(int) (a%10)] +=1 ;
a=a/10;
}
key = getKey1(b);
int value = hm.get(key)==null?1:(Integer)hm.get(key)+1;
if(value==5){
System.out.println(tempa);
}
hm.put(key, value); i = i - 1;
}
} public static void main(String[] args) {
long begin= System.currentTimeMillis();
new P62().run1(); //127035954683
long end = System.currentTimeMillis();
long Time = end - begin;
System.out.println("Time:"+Time/1000+"s"+Time%1000+"ms"); }
}

上面的程序有个小问题:是以递减的顺序找的值,但是输出来两个结果,小的那个是答案。

Python程序:

import time as time

clock = time.time()

P = {}
C = {}
i = 1
j = 5 while True:
c=i*i*i
k= ''.join(sorted(str(c)))
if k in P:
P[k] +=1
if P[k] ==j:
print C[k]
break
else:
P[k] = 1
C[k] =c
i = i + 1
print('TIME :',time.time() - clock,'seconds')

上面的Python程序很不错,定义两个字典,一个存放key,以及出现的次数value,一个是用来存放出现的第一个数,key一样,value是这个数的大小。

欧拉工程第62题:Cubic permutations的更多相关文章

  1. 欧拉工程第69题:Totient maximum

    题目链接 欧拉函数φ(n)(有时也叫做phi函数)可以用来计算小于n 的数字中与n互质的数字的个数. 当n小于1,000,000时候,n/φ(n)最大值时候的n. 欧拉函数维基百科链接 这里的是p是n ...

  2. 欧拉工程第70题:Totient permutation

    题目链接 和上面几题差不多的 Euler's Totient function, φ(n) [sometimes called the phi function]:小于等于n的数并且和n是互质的数的个 ...

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

    题目链接 任意一条线上的三个数的和都等于9,顺时针,从最小的外圈开始,得到的序列是:432621213 和             序列 9位的字符串:三角环所能形成的最大字符串为432621513. ...

  4. 欧拉工程第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 ...

  5. 欧拉工程第66题:Diophantine equation

    题目链接 脑补知识:佩尔方差 上面说的貌似很明白,最小的i,对应最小的解 然而我理解成,一个循环的解了,然后就是搞不对,后来,仔细看+手工推导发现了问题.i从0开始变量,知道第一个满足等式的解就是最小 ...

  6. 欧拉工程第65题:Convergents of e

    题目链接 现在做这个题目真是千万只草泥马在心中路过 这个与上面一题差不多 这个题目是求e的第100个分数表达式中分子的各位数之和 What is most surprising is that the ...

  7. 欧拉工程第61题:Cyclical figurate numbers

    ---恢复内容开始--- 题目链接 从三角数开始,循环到八角数,再到三角数,求这6个数的和 这个比较复杂,代码在网上找的 Java: package project61; import java.ut ...

  8. 欧拉工程第56题:Powerful digit sum

    题目链接   Java程序 package projecteuler51to60; import java.math.BigInteger; import java.util.Iterator; im ...

  9. 欧拉工程第55题:Lychrel numbers

    package projecteuler51to60; import java.math.BigInteger; import java.util.Iterator; import java.util ...

随机推荐

  1. 启动 mysql 失败 Warning:The /usr/local/mysql/data directory is not owned by the 'mysql' or '_mysql'

    Warning:The /usr/local/mysql/data directory is not owned by the 'mysql' or '_mysql' 这应该是某种情况下导致/usr/ ...

  2. 团队自动化环境搭建与管理--php博弈

    我是方少,很开心与大家日后与大家交流技术上面的一些想法和一些业务上的分享.以前从来没写过博客,因为觉得不重要吧,如今觉得有必要沉淀一些想法和回忆.好了费话不多说. 先上图: 业务问题:在每次新伙伴加入 ...

  3. Javascript(JS)中的大括号{}和中括号[]详解

    一.{ } 大括号,表示定义一个对象,大部分情况下要有成对的属性和值,或是函数. 如:var LangShen = {"Name":"Langshen",&qu ...

  4. java 环境变量设置

    JAVA_HOME  C:\Program Files\Java\jdk1.7.0 PATH %JAVA_HOME%\bin;%JAVA_HOME%\jre\bin; CLASSPATH .;%JAV ...

  5. protected internal修饰符

    见过这样的修饰符,但是没有仔细考虑过,今天做一个小练习. 先给出一个链接,别人在网上讨论的:http://wenku.baidu.com/view/4023f65abe23482fb4da4cfe.h ...

  6. 【WPF学习日记——[DevExpress]】GridControl 行中使用按钮

    想到的办法都试了,只有这个能用,不一定是最好的,但却是自己能想到的,记录一下. <dxg:GridColumn Header="操作" Width="134&quo ...

  7. TIME_WAIT引起Cannot assign requested address报错

    1.  问题描述 有时候用redis客户端(php或者java客户端)连接Redis服务器,报错:"Cannot assign requested address." 原因是客户端 ...

  8. 【http】http/1.1 八种请求方式

    OPTIONS 返回服务器针对特定资源所支持的HTTP请求方法.也可以利用向Web服务器发送'*'的请求来测试服务器的功能性. HEAD 向服务器索要与GET请求相一致的响应,只不过响应体将不会被返回 ...

  9. Quartz.net 的开源任务管理平台

    Quartz.net 的开源任务管理平台 前面总结了很多,关于Quartz.net 的文章,介绍了如何使用Quartz.net.不清楚的朋友,可以看我之前的系列文章,http://www.cnblog ...

  10. audio 设置 currentTime 失效 的解决办法

    当服务端返回的 音频文件标示 no-cache 的时候,会引起currentTime 失败. 改掉server 返回头信息.解除禁止缓存,一切ok.