您的位置:

java水仙花,JAVA水仙花实训总结

本文目录一览:

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

按一下代码执行:

public class woo {

public static void main(String args[]) {

System.out.println("100-1000中的水仙花数有:");

for(int i=100;i1000;i++){

int single  = i%10;

int ten = i/10%10;

int hundred = i/10/10%10;

//水仙花数判断要求

if(i == (single*single*single+ten*ten*ten+hundred*hundred*hundred)){

System.out.println(i);

}

}

}

}

扩展资料:

水仙花数只是自幂数的一种,严格来说3位数的3次幂数才称为水仙花数。

一位自幂数:独身数

两位自幂数:没有

三位自幂数:水仙花数

四位自幂数:四叶玫瑰数

五位自幂数:五角星数

六位自幂数:六合数

七位自幂数:北斗七星数

八位自幂数:八仙数

九位自幂数:九九重阳数

十位自幂数:十全十美数

参考资料:

水仙花数——百度百科

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的水仙花束程序

法一:import java.awt.*;

import java.applet.*;

import java.math.*;

public class Shuixianhua extends Applet {

public void init() {

}

public void paint(Graphics g) {

//定义相关变量

int elem[]=new int[4];

int num,temp;

double total;

int row=20,column=30;

int count=0,k;

g.drawString("4位的水仙花数如下所示:", 20, 30 );

//利用循环寻找1000到10000之间的水仙花数

for(num=1000; num10000; num++)

{

k=0;

temp=num;

//提取num中的千位,百位,十位,个位,存储在整型数组elem[4]中

do

{ elem[k]=temp%10;

temp=temp/10;

k++;

}while(!(temp==0));

total=Math.pow(elem[0],4)+Math.pow(elem[1],4)+Math.pow(elem[2],4)+Math.pow(elem[3],4);

//判断是否未水仙花数

if(total==num)

{

count++;

//输出格式控制

if(count%8==0)

{

row=row+25;

}

else

{

column=column+30;

}

g.drawString(num+"是水仙花数",row,column);

}

column=column+30;

g.drawString("共"+count+"个",row,column);

}

}

法二:public class Sxhs{

public static void main(String[] agrs){

int a1 , a2 , a3;

for(int i=1000 ; i10000 ; i++){

a1 = i / 1000;

a2=(i-a1*1000)/100;

a3=i-a1*1000-a2*100;

if(i==(a1*a1*a1)+(a2*a2*a2)+(a3*a3*a3)){

System.out.println("shi : " + i);

}

}

}

}

法三:public class shuixianhua{

public static void main(String[] agrs){

int a1 , a2 , a3,a4;

for(int i=1000 ; i10000 ; i++){

a1 = i / 1000;

a2=(i-a1*1000)/100;

a3=(i-a1*1000-a2*100)/10;

a4=i-a1*1000-a2*100-a3*10;

if(i==(a1*a1*a1*a1)+(a2*a2*a2*a2)+(a3*a3*a3*a3)+(a4*a4*a4*a4)){

System.out.println("shi : " + i);

System.out.println(a1);

System.out.println(a2);

System.out.println(a3);

System.out.println(a4);

}

}

}

}

法四:public class Suixian {

public static void main(String[] args) throws java.io.IOException {

byte[] buf = new byte[20];

int cmdLength = System.in.read(buf);

String str = new String(buf,0,cmdLength-2);

int n = Integer.parseInt(str);//这里当然是输入一个位数罗,也不一定就三位吧

int low = 1,high = 1;

for (int i=1;in;i++) low = low*10;

high = low * 10;

//System.out.println(low);

//System.out.println(high);

for (int i=low;ihigh;i++)

{

int sum = 0;

int p = i;

while (p!=0)

{

int r = p%10;

p = p/10;

int rn = 1;

for (int j=1;j=n;j++) rn = rn * r;

sum = sum + rn;

}

if (sum==i) System.out.println;

}

}

}

不过这只是法一的一个化简,(法一用了一个数组)

第二个方法是这样,拿三未数举例

public class SuiXian2 {

public static void main(String[] args) {

for (int a=1;a=9;a++)

for (int b=0;b=9;b++)

for (int c=0;c=9;c++)

if(a*a*a+b*b*b+c*c*c==100*a+10*b+c)

System.out.println(100*a+10*b+c);

}

}

java求水仙花数,怎么样统计水仙花数的个数啊?

统计水仙花数的个数的话可以使用一个变量来计数,循环判断如果这个数是水仙花数的话,就把这个数加1。

具体示例代码如下:

publicclassDemo1{

publicstaticvoidmain(String[]args){

System.out.println(\\\"100~999之间的水仙花数是:\\\");

intcount=0;

for(intcustNo=100;custNolt;=999;custNo++){

intgeWei=custNo%10;

intshiWei=custNo/10%10;

intbaiWei=custNo/100%10;

if(custNo==geWei*geWei*geWei+shiWei*shiWei*shiWei+baiWei*baiWei*baiWei){

count++;

System.out.println(custNo);

}

}

System.out.println(\\\"个数:\\\"+count);

}

}

接下来介绍下什么是水仙花数:

水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。

java水仙花数?

100以内是没有水仙花数的!

水仙花数定义:水仙花数是指一个

n

位数

(

n≥3

),它的每个位上的数字的

n

次幂之和等于它本身。(例如:1^3

+

5^3

+

3^3

=

153)

//100-999之间的数

public

class

Demo

{

public

static

void

main(String

[]

a){

for

(int

i=101;i999;i++){

String

s=new

Integer(i).toString();

int

temp=0;

int

n=s.length();

for

(int

j=0;jn;j++){

temp+=Math.pow(Character.digit(s.charAt(j),

10),

n);

}

if(temp==i){

System.out.println(i);

}

}

}

}

//不太清楚你所说的100间的斐波那契数是什么概念

是100以内的斐波那契数

还是100步以内的斐波那契数,下面给你写的程序里面n是步数

public

class

Demo

{

public

static

void

main(String[]

args)

{

int

n

=

20;

fib(n);

}

public

static

void

fib(int

n)

{

long

f1

=

1,

f2

=

1,

fn

=

0;

if

(n

==

1)

System.out.print(f1);

if

(n

==

2)

System.out.print(f2);

else

{

System.out.print(f1+"

");

System.out.print(f2+"

");

for

(int

i

=

2;

i

n;

i++)

{

fn

=

f1

+

f2;

f1

=

f2;

f2

=

fn;

System.out.print(fn+"

");

}

}

}

}