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+"為水仙花數");
}
}
}
}
代碼截圖:
嚴格意義上來說,只有三位數才能被稱為水仙花數,但其他位數的數同樣也有符合水仙花數規則的,這些數有其他別稱,如:
一位自冪數:獨身數
三位自緩搭冪數:水仙花數如:銀廳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+"個"); //輸出水仙花數的總數
}
}