欧拉工程第62题:Cubic permutations
找出最小的立方数,它的各位数的排列能够形成五个立方数
解决关键点:
这五个数的由相同的数组成的
可以用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的更多相关文章
- 欧拉工程第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是互质的数的个 ...
- 欧拉工程第68题:Magic 5-gon ring
题目链接 任意一条线上的三个数的和都等于9,顺时针,从最小的外圈开始,得到的序列是:432621213 和 序列 9位的字符串:三角环所能形成的最大字符串为432621513. ...
- 欧拉工程第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 ...
- 欧拉工程第61题:Cyclical figurate numbers
---恢复内容开始--- 题目链接 从三角数开始,循环到八角数,再到三角数,求这6个数的和 这个比较复杂,代码在网上找的 Java: package project61; import java.ut ...
- 欧拉工程第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 ...
随机推荐
- width100%,设置padding或border溢出解决方法
.box { width: 100px; height: 100px; background: red;} .bd { width: 100%; padding: 10px; background: ...
- 联想预装win8系统改成win7操作步骤及注意事项
联想消费台式机与一体机预装Windows8改装Windows7的操作步骤及常见问题 前提说明: 目前联想出厂预装Windows 8的台式和一体机使用都是UEFI+GPT硬盘的组合,并且开启了安全启动, ...
- devpress控件属性说明表
XtraEditors 库中所有控件的公共功能 全部都可以绑定数据: 全部都可以独立使用或用于由 Developer Express 提供的容器控件(XtraGrid.XtraVerticalGrid ...
- 反编译APK终结教程
现在来教大家如何由网上下载的Android应用反编译为源码.如果你感兴趣,就来看一看吧.前提是你的电脑得已经配置好了java环境,如果没有配置好的话,下面我会附带一提,如果你还是不懂的话,那就上网搜一 ...
- Python-Day5 常用模块学习
一.模块介绍 通俗点说,就是把常用的一些功能单独放置到一个.py文件中,方便其他文件来调用,这样的一个文件可以称为一个模块. 模块分为三种: 自定义模块 内置标准模块(又称标准库) 开源模块 二.导入 ...
- WPF 一个弧形手势提示动画
这是一个操作提示动画,一个小手在屏幕上按照一个弧形来回运动 <Window x:Class="LZRichMediaWall.MainWindow" xmlns=" ...
- [转]Oracle学习记录 九 Prc C学习
经过前面的了解,现在想用C语言来编程了,搜索了很多东西,后来决定先用Pro C来进行学习 在安装完Oracle数据库后就可以进行编程了,里面有一个命令proc就是对程序进行预编译的. 在这记一下,这是 ...
- mysql学习笔记之基础篇
数据库学习之基础篇 ① 开放数据库互连(Open Database Connectivity,ODBC ② 结构化查询语言(Structured Query Language) ③ 进入mysql:M ...
- TTL值的含义以及与域名DNS TTL值的区别
TTL值的含义以及与域名TTL值的区别 本文来源于时光漂流瓶 http://www.9usb.net , 原文地址: http://www.9usb.net/201004/ttl-yuyuming-t ...
- [ios]ipad下的splitViewController 让你的APP看起来酷酷的!
在ipad下可以使用splitViewController splitViewController下包含两个viewController 这是一种将屏幕一分为二的方式. 在水平状态下会出现成两个左右两 ...