java计算自幂数和水仙花数_java

(例如:当n为3时,有1^3 + 5^3 + 3^3 = 153,153即是n为3时的一个自幂数)
n为1时,自幂数称为独身数。
n为2时,没有自幂数。
n为3时,自幂数称为水仙花数。
n为4时,自幂数称为玫瑰花数。
n为5时,自幂数称为五角星数。
n为6时,自幂数称为六合数。
n为7时,自幂数称为北斗七星数。
n为8时,自幂数称为八仙数。
n为9时,自幂数称为九九重阳数。
n为10时,自幂数称为十全十美数。

复制代码 代码如下:

/*
 * 自幂数
 * 自幂数是指一个 n 位数,它的每个位上的数字的 n 次幂之和等于它本身。
 * (例如:当n为3时,有1^3 + 5^3 + 3^3 = 153,153即是n为3时的一个自幂数)
 */
import java.util.Scanner;

public class 自幂数 {

 public static void main(String[] args) {
  Scanner input = new Scanner(System.in);
  System.out.println("请输入您所要查的自幂数位数:");
  int n = input.nextInt();// 接收数字位数
  // 定义一数字number,从10^(n-1)开始自加,到10^n结束
  switch (n) {
  case 1:
   System.out.println("独身数:");
   System.out.print("0" + "\t");
   break;
  case 2:
   System.out.println("两位自幂数:");
   System.out.println("没有自幂数!");
   break;
  case 3:
   System.out.println("水仙花数:");
   break;
  case 4:
   System.out.println("玫瑰花数:");
   break;
  case 5:
   System.out.println("五角星数:");
   break;
  case 6:
   System.out.println("六合数:");
   break;
  case 7:
   System.out.println("北斗七星数:");
   break;
  case 8:
   System.out.println("八仙数:");
   break;
  case 9:
   System.out.println("九九重阳数:");
   break;
  case 10:
   System.out.println("十全十美数:");
   break;
  default:
   System.out.println("其它自幂数:");
   break;
  }
  for (int number = (int) Math.pow(10, n - 1); number < Math.pow(10, n); number++) {
   // 判断条件:数字number的位数为n
   if (String.valueOf(number).length() == n) {
    double num = 0;
    for (int i = 0; i < n; i++) {
     int temp = (int) (number / Math.pow(10, i)) % 10;
     num += Math.pow(temp, n);
    }
    if (number == num) {
     System.out.print(number + "\t");
    }
   }
  }
  input.close();
 }
}

时间: 2024-07-31 06:10:07

java计算自幂数和水仙花数_java的相关文章

java计算自然数中的水仙花数的方法分享_java

复制代码 代码如下: /** * m-n自然数中的水仙花数 * @param n * @param m */static void getNums(int n,int m){for(int i=m;i<=n;i++){int ge,shi,bai;double shui;bai=i/100;shi=i%100/10;ge=i%10;shui=Math.pow(bai, 3)+Math.pow(shi, 3)+Math.pow(ge, 3);if(i==shui)System.out.printl

利用Java计算某个日期是星期几_java

话不多说,下面来直接看示例代码 具体代码: DayOfWeek4Birthday.java package com.gua; import java.util.Calendar; import java.util.GregorianCalendar; import java.io.*; import static java.lang.System.out; /** * Created by 2gua on 2014/9/27. * DayOfWeek4Birthday:看看你查询的具体日子是星期

语言 水仙花数算法-水仙花数代码如何减短运行时间

问题描述 水仙花数代码如何减短运行时间 水仙花数是指一个N位正整数(N>=3),它的每个位上的数字的N次幂之和等于它本身.例 如:153 = 13 + 53+ 33. 本题要求编写程序,计算所有N位水仙花数. 输入格式: 输入在一行中给出一个正整数N(3<=N<=7). 输出格式: 按递增顺序输出所有N位水仙花数,每个数字占一行. 输入样例:3 输出样例:153 370 371 407 我的代码运行起来超时;我知道可能是n=7时循环次数太多造成的.有什么办法解决呢 include inc

java计算任意位水仙花数示例(回文数)_java

可计算任意位水仙花数 复制代码 代码如下: public static void main(String[] args) {  int max = 10;  for (int len = 1; len <= max; len++) {   System.out.println(getNarc(len, ""));  } }  static StringBuffer strb = new StringBuffer();  static String getNarc(int len,

java我写的这个求水仙花数为什么算不出来

问题描述 java我写的这个求水仙花数为什么算不出来 import java.util.Scanner; public class Task1{ public static void main(String[] args) { Scanner input = new Scanner(System.in); System.out.print("请输入一个数"); int number = input.nextInt(); double s=0; int[] a={0}; int i; f

帮忙完善一个非常简单的java 程序 水仙花数

问题描述 我对java刚入门帮忙看看这个程序运行不了有错误啊大家帮忙啊.水仙花数输出importjava.io.*;publicclassinputClass{publicstaticvoidmain(Stringargs[]){inta=0,b=0,c=0;for(i=100;i<1000;i++)a=i/100;b=(i/10)%10;c=i%10;if(a*a*a+b*b*b+c*c*c==i)System.out.println(i);}}改下也行重新告诉我一个更简单的也行 解决方案 解

java计算两个时间相差天数的方法汇总_java

问题描述: 输入:两个日期 输出:两个日期相差的天数 具体代码实现 方法1: 通过Calendar类的日期比较.注意:这里需要考虑一下: 日期是跨年份的,如一个是2012年,一个是2015年的 年份是分闰年和平年的,各自的天数不同 /** * date2比date1多的天数 * @param date1 * @param date2 * @return */ public static int differentDays(Date date1,Date date2) { Calendar cal

php中如何求水仙花数优化

水仙花数是指一个n位数(n>=3),它每个位上数字的n次幂之和等于它本身,n为它的位数.(例如:1^3+5^3+3^3 = 153) 水仙花数又称阿姆斯特朗数. 三位的水仙花数有4个:153,370,371,407 四位的水仙花数有3个:1634,8208,9474 五位的水仙花数有3个:54748,92727,93084 六位的水仙花数有1个:548834 七位的水仙花数有4个:1741725,4210818,9800817,9926315 八位的水仙花数有3个:24678050,246780

关于JAVA经典算法40题(超实用版)_java

[程序1]题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?1.程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21....public class exp2{ public static void main(String args[]){ int i=0; for(i=1;i<=20;i++)System.out.println(f(i));}public static int f(in