实验代码:
/*
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称: TestNumber.java
* 作 者: 张宗佳
* 完成日期: 2012 年 9 月 16 日
* 版 本 号: v1.0
* 对任务及求解方法的描述部分
* 问题描述:编写一个Java应用程序,用户从键盘输入一个1~9999之间的数,程序将判断这个*数是几位数,并判断这个数是否是回文数。回文数是指将该数含有的数字逆序排列后得到的数*和原数相同,例如12121、3223都回文数。代码附后。
* 算法说明:
* 程序头部的注释结束
*/
import javax.swing.JOptionPane;
public class TestNumber
{
public static void main(String args[])
{
loopNumber();
}
static void loopNumber(){
int number=0,d5,d4,d3,d2,d1;
String str=JOptionPane.showInputDialog("输入一个1至99999之间的数");//对话框的形式
number=Integer.parseInt(str);//转换
if(number > 1 && number < 99999) //判断number在1至99999之间的条件
{
d5 = number / 10000;//计算number的最高位(万位)d5
d4 = number / 1000 % 10;//计算number的千位d4
d3 = number % 1000 / 100; //计算number的百位d3
d2=number % 100 / 10;
d1=number % 10;
if(d5 > 0) //判断number是5位数的条件
{
System.out.println(number+"是5位数");
if(d5 == d1 && d4 == d2) //判断number是回文数的条件
{
System.out.println(number+"是回文数");
}
else
{
System.out.println(number+"不是回文数");
}
}
else if(d5 == 0 && d4 > 0) //判断number是4位数的条件
{
System.out.println(number+"是4位数");
if(d1 == d4 && d2 == d3) //判断number是回文数的条件码
{
System.out.println(number+"是回文数");
}
else
{
System.out.println(number+"不是回文数");
}
}
else if(d5 == 0 && d4 == 0 && d3 > 0) //判断number是3位数的条件
{
System.out.println(number+"是3位数");
if(d1 == d3) //判断number是回文数的条件
{
System.out.println(number+"是回文数");
}
else
{
System.out.println(number+"不是回文数");
}
}
else if(d2!=0)
{
System.out.println(number+"是2位数");
if(d1==d2)
{
System.out.println(number+"是回文数");
}
else
{
System.out.println(number+"不是回文数");
}
}
else if(d1!=0)
{
System.out.println(number+"是1位数");
System.out.println(number+"是回文数");
}
}
else
{
System.out.printf("\n%d不在1至99999之间",number);
}
}
}
实验结果:
1221是4位数
1221是回文数