本帖最后由 佟亚鹏 于 2012-9-21 13:17 编辑
楼主,这个问题的关键是拿到数字的个位、十位、百位,给你一段代码,你可以参考下,这个算法是利用java中double类型转int类型,会把小数部分去掉 除了这个算法还可以用,分析字符串,进行转型(Integer.parseInt这个方法),这个效率没有,上面的数值运算快 代码如下: public class FlowerNumber {
public static void main(String[] args) {
/*利用for循环控制100-999个数,每个数分解出个位,十位,百位。 */
for (int i = 100;i < 1000;i++) {
if (Number.isDaffodilsNumber(new Number(i))) {
System.out.print(i + " ");
}
}
}
}
class Number {
private int number;
public Number(int number) {
this.number = number;
}
public static boolean isDaffodilsNumber(Number number) {
int num = number.getNumber();
if (num < 100 || num > 999)return false;
//获得num的百位,例如345除去100等于3.45由于是int型java会把小数部位去掉就剩3了,这个算法就是使用这个原理
int hundred = num / 100;
//获得num的个位 通过这个操作num / 10 * 10会把个位数变成0,然后拿num减去这个数字就拿到个位数了
int unit = num - (num / 10 * 10);
//获得num的十位 通过num / 10这个操作就只保留了前两位,hundred * 10获得百位数字乘以100,减一下获得十位
int decade = (num / 10) - (hundred * 10);
int result = unit * unit * unit + decade * decade * decade + hundred * hundred * hundred;
if (num == result)
return true;
return false;
}
public int getNumber() {
return number;
}
public void setNumber(int number) {
this.number = number;
}
}
|