问题描述
123321是一个非常特殊的数,它从左边读和从右边读是一样的。
输入一个正整数n, 编程求所有这样的五位和六位十进制数,满足各位数字之和等于n 。
输入格式
输入一行,包含一个正整数n。
输出格式
按从小到大的顺序输出满足条件的整数,每个整数占一行。
样例输入
52
样例输出
899998
989989
998899
数据规模和约定
1<=n<=54。
思路
逐步地取出单个位数上的数进行整体判断, 必然使用循环解题。
题目分析
首先,按照题意,品一下这个约定“1<=n<=54”意味着什么。1肯定不必说,54则是限定了其最高位,6*9=54。也就是说,使用循环来解题它的上限就是999999。下限则根据题目中所写的“五位和六位十进制数”其下限就是10000。
确定了循环的范围,接下来便简单了。无非是取出各个位上的数,相加进行判断是否等于题目所给值。判断相等后再根据数字的位数是5位还是6位进行首位和末尾,次位和倒数第二位等等的判断。
代码
import java.io.*;
import java.util.*;
public class Main{
public static void main(String[] args){
//对象声明
Scanner sc = new Scanner(System.in);
//获取所给值
int n = sc.nextInt();
//各位进行声明
int ge, shi, bai, qian, wan, shiWan;
//通过确定的循环范围来进行每个数的判断
for(int i=10000; i<999999; i++){
//分别取出每个数
ge = i % 10;
shi = i / 10 % 10;
bai = i / 100 % 10;
qian = i / 1000 % 10;
wan = i / 10000 % 10;
shiWan = i / 100000 % 10;
//若与所给值不相等,跳过
if(ge+shi+bai+qian+wan+shiWan != n){
continue;
}
//将与所给值相等的数转换为字符串,方便进行5或6位数的判断
String str = ""+i;
//5位数回文数要求首位与末位、次位与次末位相等
if(str.length() == 5 && ge == wan && shi == qian){
System.out.println(i);
}
//6位数回文数则在5位数的要求上添加第三位与倒数第三位相等的条件即可
if(str.length() == 6 && ge == shiWan && shi == wan && bai == qian){
System.out.println(i);
}
}
}
}