回文数字

解析: 这题我觉得主要考察的地方是字符串的使用,主要是两个地方,一个是字符串的逆序,另一个是字符串中字符的相加。字符串的逆序实现方法比较多,我比较常用的是用过String类的substring()方法将这个字符串从后往前截取,拼成一个新的逆序字符串;也可以使用StringBuffer类的reverse()方法将字符串进行逆序,这个方法就会简单一些。(这里有个需要注意的地方是:当需要截取字符串中的字符进行int类型的相加时,是不可以使用charAt()方法进行截取的,字符相加时是用当前字符在ASCII码中的排序进行相加的,例如字符'1'相当于48.所以我这里用的是substring()方法)

题目比较简单,直接上代码

package _12_26_test;
/*回文数字
 * 
 * 数字满足以下两个条件:
 * 1、输入n,abc符合a+b+c=n
 * 2、abc=cba
 * 3、数字居于10000、999999之间
 * 
 * 
 * 字符串的逆序
 * 
 * */

import java.util.Scanner;



public class fourteen {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		Scanner scanner = new Scanner(System.in);

		int num = scanner.nextInt();
		boolean flag = false;

		for (int i = 10000; i < 999999; i++) {
			String strTem = String.valueOf(i);
			int intTem = 0;
			String reTem = "";
			// 各个位数相加
			for (int j = 0; j < strTem.length(); j++) {
				intTem = intTem + Integer.parseInt(strTem.substring(j, j+1));
			}
			if (intTem == num) {
				// 若符合各个位数相加等于n,进行回文数判断
				for (int k = 0; k < strTem.length(); k++) {
					reTem = reTem + strTem.substring(strTem.length()-1-k,strTem.length()-k );
				}
				if (reTem.equals(strTem)) {
					flag = true;
					System.out.println(i);
				}

			}

		}

		if (!flag) {
			System.out.println(-1);
		}

	}

}

posted @ 2020-04-18 11:50  西红柿里没有番茄  阅读(184)  评论(0编辑  收藏  举报