• 回文数字


    解析: 这题我觉得主要考察的地方是字符串的使用,主要是两个地方,一个是字符串的逆序,另一个是字符串中字符的相加。字符串的逆序实现方法比较多,我比较常用的是用过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);
    		}
    
    	}
    
    }
    
    
  • 相关阅读:
    c# 一段生成6位不重复的随机数字码存8万个
    element ui 踩坑记
    Vue node.js 踩坑记
    javascript 异步回调链式调用 promise
    css 盒模型
    vue node.js 引入 linq
    Vue VsCode 项目 launch.json 文件
    node.js 基本语法识记
    Vue 2.0 入门示例识记
    在Windows系统中建立一个隐藏的帐户(在不登录界面显示)
  • 原文地址:https://www.cnblogs.com/lyd447113735/p/12724956.html
Copyright © 2020-2023  润新知