设为首页 收藏本站
查看: 931|回复: 0

[经验分享] 求一个int型整数的两种递减数之和(java)--2015华为机试题

[复制链接]

尚未签到

发表于 2017-7-11 06:26:53 | 显示全部楼层 |阅读模式
  题目描述: 给出一个整数(负数使用其绝对值),输出这个整数中的两种递减数(1.最大递减数;2.递减数中各位数之和最大的数)之和。
  递减数:一个数字的递减数是指相邻的数位从大到小排列的数字,不包含相邻的数位大小相同的情况。
  最大递减数:所输入整数的所有递减数中值最大的一个。 如: 75345323,递减数有:75,753,53,53,532,32。那么最大的递减数为753。
  各位数字之和最大的递减数: 如75345323中的各递减数:75各位数之和=12(7+5=12),753各位数之和=15(7+5+3=15),53各位数之和=8(5+3=8),532各位数之和=10(5+3+2=10),32各位数之和=5(3+2=5)。那么各位数字之和最大的递减数为753。
  输出结果=最大递减数+各位数之和最大的递减数。(1506=753+753)
  运行时间限制:        无限制
  内存限制:        无限制
  输入:        一个int型整数。如:75345323
  输出:        一个int型整数。如:1506
  样例输入:        75345323
  样例输出:        1506



import java.util.ArrayList;
import java.util.Iterator;
import java.util.Scanner;

public class subtraction {
     public static void main(String[] args)
     {
         Scanner scan =new Scanner(System.in);
         String str =scan.nextLine();
         diJianShu(str);
            
     }
     static void diJianShu(String str)
     {
         char[] arr=str.toCharArray();
         ArrayList<Integer> la=new ArrayList<Integer>();        //用来存放递减数
         for(int i=0;i<arr.length-1;i++)      //寻找递减数
         {
             if(arr>arr[i+1])
             {
                 String s=""+arr+arr[i+1];
                 la.add(Integer.parseInt(s));
                 for(int j=i+1;j<arr.length-2;j++)
                 {
                     if(arr[j]>arr[j+1])
                         {
                         s=s+arr[j+1];
                         la.add(Integer.parseInt(s));
                         break;             //防止角标继续往下比
                         }
                     break;                //防止角标继续往下比
                 }
                 s=null;
             }   
         }
//        Iterator<Integer> it=la.iterator();
//        while(it.hasNext()){
//            System.out.print(it.next()+" ");
//        }
         String[] a=new String[la.size()];//将集合里的元素转化成字符串,再转化成字符数组,方便下面求递减数各位数之和
         int max=0;                      //记录最大递减数
         for(int i=0;i<la.size();i++)
         {
             if(la.get(i)>max)
             {
                 max=la.get(i);            //找到最大递减数
             }
             a=la.get(i).toString();   // 将集合里的元素转化成字符串
         }
         String ss=null;
         int max2=0;                     //记录最大递减数之和
         for(String string :a)
         {                               //字符串转化为字符数组,方便下面求递减数各位数之和
             if(string!=null)
             {
                 char[] ch=string.toCharArray();
                 int num=0;
                 for(int i=0;i<ch.length;i++)
                 {
                     num=num+ch-48;
                 }
                 if(num>max2)
                 {
                     max2=num;           //找到最大递减数之和
                     ss=string;         //记录下最大递减数之和的字符串;
                 }
             }
            
         }
         int sum=max+Integer.parseInt(ss);
         System.out.println(sum);   
     }
}
  逻辑思路:
  1、输入字符串并读取;
  2、判断输入的是否为负数;(这步省略了,在一开始编的时候加进去了,后来删掉了)
  3、判断递减数;(这步很关键,逻辑要清晰,我是用了嵌套for循环,改错的时候找了好久)
  4、将得到的递减数重新装进一个集合里;
  5、判断最大递减数;
  6、判断数字之和最大的递减数。
  作为一个近期正在刷题的初学者来说,这题我从上午一直编到下午,这题也没有那么难,但却是自己在看了网上其他答案觉得都不好,然后自己理了理逻辑就开始码了起来,虽然花费了很长时间,而且改错改了一个多小时,但是还是很有成就感的。毕竟花了那么长时间,就作为第一篇帖子分享给大家吧,希望对大家有用。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-392576-1-1.html 上篇帖子: 华为实习日记——第三十四天 下篇帖子: 华为实习日记——第三十七天
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表