------Java培训、Android培训、iOS培训、.Net培训、期待与您交流! -------
/**
* 第二题: 从键盘接受一个数字,列出该数字的中文表示格式,例如:键盘输入123,打印出一二三;键盘输入3103,打印出三一零三。
*
* @author XiaoLu
*/
//导入Scanner的包
import java.util.Scanner;
public class Test2 {
public static void main(String[] args) {
method();
}
/**
* method方法 功能:从键盘录入一个整数。
*/
public static void method() {
// 创建一个Scanner对象
Scanner sc = new Scanner(System.in);
// 添加提示语句
System.out.println("----->请输入一个整数<-----");
// 创建一个临时变量,用于接收用户输入的值
int temp = sc.nextInt();
//调用method_1方法,传入用户输入的参数
method_1(temp);
}
/**
* 功能:传入一个参数,并且转换为对应的汉字数字显示
* 传入参数:int类型的值
*
* 处理方法:
* 1、定义一个字符串数组,保存汉字数字
* 2、然后将传入的数字转换成字符串,并且求出字符串的长度,
* 3、根据求出的的字符串长度,调用pow方法,计算出传入数字的最高位位权值
* 4、通过循环对传入数字取余操作,打印输出
*
* @param temp
*/
public static void method_1(int temp) {
// 定义一个汉字数组,对于数字的0-9,
String[] arr = { "零", "一", "二", "三", "四", "五", "六", "七", "八", "九" };
// 将整数转换成字符串
String s = "" + temp;
// 计算字符串长度,就可以知道数字的长度
int length = s.length();
/*
* 计算出最高位对应的位权,因为获取的字符串长度比对应的位权值得长度大一位,所以长度需要减一
* 例子:输入的是123,那么得到的字符串是3位,如果不减一的话,计算出来的权值为1000,
* 我们需要的是100,所以输入的幂需要减一,
* pow方法计算的结果是一个double类型,所以需要强转为整型
*/
length = (int) Math.pow(10, length - 1);
/*
* 计算结果每次以对位权取整输出,然后权值除以10,直到位权为0为止
*/
for (int i = length; i > 0; i /= 10) {
//取出最高位输出
System.out.print(arr[temp / i]);
//然后取出余数部分,继续运算
temp = temp % i;
}
}
}
源代码下载地址:http://download.csdn.net/detail/lmh820822/8351861