导航:首页 > 源码编译 > java水仙花数算法优化

java水仙花数算法优化

发布时间:2023-05-16 14:24:09

1. java计算9位以下水仙花数怎么优化


publicstatic丛尘voidmain(String[]args)渗野禅{
List<Integer>list=newArrayList<>();
longstart=System.currentTimeMillis();
// System.out.println(fix(1634,"1634"));
for(intn=100;n<1000000;n++){
if(n==fix(n,String.valueOf(n))){
list.add(n);
}
}
longend=System.currentTimeMillis();
System.out.println((end-start)/1000);
System.out.println(list);
}
staticintfix(intx,Stringy){

// Math.pow(a,b);
if(x/10<1){
return(int)Math.pow(x,y.length());
}else{
intn=x%10;
// System.out.println("n="+n+"脊祥;x/10="+x/10+";y="+y);

returnfix(x/10,y)+(int)Math.pow(n,y.length());
}
}

2. 用Java写个关于“水仙花数”的程序

代码如下:

public class shuixianhua {

public static void main(String[] args) {

for (int i = 100; i <1000 ; i++) {

int BaiNum = i/100;//分解出百位

int ShiNum = i/10%10;//分解出十位

int GeNum = i%10;//分解出个位

//判断是否为水仙花数,即百位的锋哪隐三次方+十位的三次方+个位的三次方=数字本身

if(BaiNum*BaiNum*BaiNum + ShiNum*ShiNum*ShiNum+GeNum*GeNum*GeNum == i){

System.out.println(i+"为水仙花数");

}

}

}

}

代码截图:

(2)java水仙花数算法优化扩展阅读:

严格意义上来说,只有三位数才能被称为水仙花数,但其他位数的数同样也有符合水仙花数规则的,这些数有其他别称,如:

一位自幂数:独身数

三位自缓搭幂数:水仙花数如:银厅153,370,371,407;

四位自幂数:四叶玫瑰数如:1634,8208,9474;

五位自幂数:五角星数如:54748,92727,93084;

六位自幂数:六合数如:548834;

七位自幂数:北斗七星数如:1741725,4210818,9800817,9926315;

八位自幂数:八仙数如:24678050,24678051,88593477;

九位自幂数:九九重阳数如:146511208,472335975,534494836,912985153;

十位自幂数:十全十美数如:4679307774;

3. java中求解水仙花数的算法思想是什么

水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。
从上面的定义可以看出,只要将给出的数字各个位数的数字分解出来,然后把个数字的3次方相加与原数相比是否相等即可判断出是否为水仙花数,给你一段源码,是求100~1000内的水仙花数,有注释,希望对你有帮助:
public class Wflower {
public static void main(String[] args) {
int a=0,b=0,c=0;
System.out.println("水仙花数是:");
for (int i = 100; i < 1000; i++) //遍历所有3位数
{
a = i/100; //获取3位数中百位的数
b=i%100/10; //获取3位数中十位的数
c=i%100%10; //获取3位数中个位亩蚂的数

a = a * a * a; /野衫/计算第一位数的立方
b = b * b * b; //迅脊埋计算第二位数的立方
c = c * c * c; //计算第3位数的立方
if ((a + b + c) == i) //如果符合水仙花数
System.out.print(" "+i);
}
}
}

4. 水仙花数 java for循环的问题!

水仙花数是指一个 n 位数 ( n≥3 ),它的每个位上的数字的 n 次幂之和等于它本身。
(例如:1^3 + 5^3+ 3^3 = 153)

创建工程,或使用已有工程,在工程下创建包,包内新建一个类,命名为Narcissistic类,历枯根据自己喜好随便命名,但请保持类名与文件名一致。

先写一个函数计算一个数字的立方为多少。命名为cube()

private static int cube(int n) {
return n * n * n;
}

判断这个数是不是水仙花数,求每一位数上的数的立方和是否为原数字本身。

private static Boolean isNarcissistic(int number) {
int hundreds = number / 100;
铅链int tens = number / 10 - hundreds * 10;
int ones = number % 10;
return cube(hundreds) + cube(tens) + cube(ones) == number;
}写一个for循肢激洞环来判断那些数字是水仙花数,并输出。
for (int index = 100; index < 1000; ++index) {
if (isNarcissistic(index))
System.out.print(index + "\t");
}

5. Java 编程找出所有的水仙花数(水仙花数)。

代码如下:

package com.vo;

public class Shuixianhua {

public static void main(String[] args) {

int a=0;
int b=0;
int c=0;
for(int i=100;i<999;i++)
{
a=i/100;
b=i/10%10;
c=i%10;
if(i==(a*a*a+b*b*b+c*c*c))
System.out.println(i);
}

}

}

首先水仙花数”是指一个三位数,其各位数字立方和等于该数,

如:153是一个“改型吵水仙花数”,因为1的三次方+5的三次方+3的三次方等于153

解此题的关键是怎能样从一个三位数中分离百位数、十位数、个位数。可以这样做,设该三位数以i代表,由a,b,c三个核侍数字组成。
(1)百位数字a:a=int(i/100).
(2)十位数字b:b=int((i-100*a)/10)
(3)个位数字c:c=i-int(i/10)*10.

然后在根据上述代码可得

(5)java水仙花数算法优化扩展阅读:

水仙花数(Narcissistic number)也被称为超完全数字不变数租蚂(pluperfect digital invariant, PPDI)、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),水仙花数是指一个 3 位数,它的每个位上的数字的 3次幂之和等于它本身(例如:1^3 + 5^3+ 3^3 = 153)。

6. java水仙花数

public class ShuiXianShu
{

/**
* 题目:打印出100-999之间所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。
* 例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
* 1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。*
*/
public static void main(String[] args)
{
for(int i=100;i<=999;i++)
{
int geWei,shiWei,Wei;
Wei=i/100;
shiWei=(i-Wei*100)/10;
geWei=i-Wei*100-shiWei*10;
if(i==geWei*geWei*geWei+shiWei*shiWei*shiWei+Wei*Wei*Wei)
{
System.out.println(i);
}
}

}

}
这个是我以前做过的,楼主可以参考

7. java求水仙花数

分析:水仙花数是指:一个三位数,其各位数字立方和等于该数本身。例如:370=33+73+00.这就说明370是一个水仙冲培花数。
所以要判断一个三位数是不是水仙花数,得先取得这个三位数的的个位,十位和百位。
余判配1:先取得他的百位:int BaiWei = x/100; 因为int是整形,所以不会进行四舍五入,也不会管小数点后面的数。
再取得十位:int ShiWei = (x-BaiWei*100)/10;先用这个数减去百位数*100,再除以10,原因同上。
最后取得个位数:int GeWei = x-BaiWei*100-ShiWei*10.很明显,就能得到个位数。
2:
intb = x/100;
int s = x/100%10;
int g = x%10;
求立方的方法:
1,x = Baiwei*Baiwei*Baiwei+ShiWei*ShiWei*ShiWei+GeWei*GeWei*GeWei
2,Java提供求n次方的方法:java.lang.Math.pow(a, b);其表示为a的b次方。
最后程序:
第一种:

public class ShuiXianHuaShu {
public static void main(String[] args) {
int x = 0; //定义水仙花数的个数
for(int i=100;i<=999;i++){
int b = i/100; //取得百位数
int s = (i-100*b)/10; //取得十位数
int g = (i-s*10-b*100); //取得个位数

if(i==g*g*g+s*s*s+b*b*b){
x++; //每次符合水仙花数条件,则x+1;
System.out.print(i+" "); //输出符合条件的数
}
}System.out.println(); //换行
System.out.println("水仙花数总共有"+x+"个"); //输出水仙花数的总数
}
}

第二种:

public class ShuiXianHuaShu {
public static void main(String[] args) {
int x = 0; //定义水仙花数的个数
for(int i=100;i<=999;i++){
int b = i/100; //取得百位数
int s = i%100/10; //取得十位数
int g = i%10; //取得个位数

if(i==Math.pow(b, 3) + Math.pow(s, 3) + Math.pow(g, 3)){
x++; //每次竖指符合水仙花数条件,则x+1;
System.out.print(i+" "); //输出符合条件的数
}
}System.out.println(); //换行
System.out.println("水仙花数总共有"+x+"个"); //输出水仙花数的总数
}
}

阅读全文

与java水仙花数算法优化相关的资料

热点内容
短信删除助手文件夹 浏览:688
java办公自动化 浏览:340
php中超链接 浏览:253
linux默认路由设置 浏览:36
linux如何挂载iso 浏览:432
vs程序换文件夹后不能编译 浏览:557
安卓源码编译输入脚本没反应 浏览:47
phpmysql自增 浏览:167
把ppt保存为pdf 浏览:533
汽车密封件加密配件 浏览:887
黑马程序员15天基础班 浏览:560
java调整格式 浏览:521
香港云服务器租用价 浏览:78
linuxsublime3 浏览:560
imac混合硬盘命令 浏览:278
沈阳用什么app租房车 浏览:857
00后高中生都用什么app 浏览:239
戴尔塔式服务器怎么打开独立显卡 浏览:807
医疗程序员招聘 浏览:599
住宿app可砍价是什么意思 浏览:133