2017-08-23 华为笔试第二道编程题详解

[题目描述]

给定一个整数,给出消除重复数字以后最大的整数

输入描述 :正整数,注意考虑长整数

输出描述 : 消除重复数字后的最大整数

[示例1]

输入 : 423234

输出 : 432

[思路]

使用栈作为辅助工具,首先从前往后遍历数组

* 栈为空就压入栈

* 栈非空,判断当前数组元素是否大于栈顶元素

  * 是 , 判断栈顶元素是否在后面的数组中存在,如果存在就弹出栈顶元素

* 判断栈中是否已经存在当前数组元素,否,将当前数组元素压入栈

[参考]

http://www.cnblogs.com/pk28/p/7421214.html

[代码]

public class Test2 {

public static void main(String[] args) {        Scanner in = new Scanner(System.in);        char[] inputCharArray = in.nextLine().toCharArray();        int size = inputCharArray.length;        int[] inputArray = new int[size];

//处理输入数据        for (int i = 0; i < size; i++) {            inputArray[i] = inputCharArray[i] - ‘0‘;        }

Stack numberStack = new Stack();        for (int i = 0; i < size; i++) {           if(numberStack.isEmpty()){               numberStack.push(inputArray[i]);           }else {               int currentNumber = inputArray[i];               int stackTop = (int)numberStack.peek();               if(currentNumber > stackTop){                   boolean isExistForward = findIfExistForward(inputArray, stackTop, i + 1, size - 1);                   if(isExistForward){                       numberStack.pop();                   }               }

boolean isExistInStack = findIfExistBackward(numberStack, currentNumber);               if(!isExistInStack){                   numberStack.push(currentNumber);               }           }        }

for (int i = 0; i < numberStack.size(); i++) {            System.out.print(numberStack.get(i));        }    }

/**     * 判断inputCharArray数组中,下标从i到(length-1)是否有currentNumber的重复元素     * @param inputCharArray 源数组     * @param currentNumber     * @param i     * @param end     */    private static boolean findIfExistForward(int[] inputCharArray, int currentNumber, int i, int end) {        while (i <= end){            if(inputCharArray[i] == currentNumber){                return true;            }            i++;        }        return false;    }

/**     * 判断栈中,是否已存在currentNumber元素     * @param numberStack     * @param currentNumber     * @return     */    private static boolean findIfExistBackward(Stack numberStack, int currentNumber) {        if(numberStack.search(currentNumber) == -1){            return false;        }else {            return true;        }    }}

[测试用例]

1、输入 : 423234  输出 : 432

2、输入 : 432143214321 输出 : 4321

3、输入 : 42189214 输出 : 42891

				
时间: 2024-08-05 18:32:18

2017-08-23 华为笔试第二道编程题详解的相关文章

2017年校招全国统一模拟笔试(第二场)编程题集合-牛客网

 2017年校招全国统一模拟笔试(第二场)编程题集合-牛客网 链接:https://www.nowcoder.com/questionTerminal/276712b113c6456c8cf31c5073a4f9d7来源:牛客网 牛牛有两个字符串(可能包含空格),牛牛想找出其中最长的公共连续子串,希望你能帮助他,并输出其长度. 输入描述: 输入为两行字符串(可能包含空格),长度均小于等于50. 输出描述: 输出为一个整数,表示最长公共连续子串的长度. 输入例子: abcde abgde 输出例子

关于SQL的几道小题详解

关于SQL的几道小题详解 当我们拿到题目的时候,并不是急于作答,那样会得不偿失的,而是分析思路,采用什么方法,达到什么目的,还要思考有没有简单的方法或者通用的方法等等,这样才会达到以一当十的效果,这样的惯性思维其实早在我们度高中的时候就被领教了,所谓“万变不离其宗”吧.以下各题来自日常所见,或QQ群,或面试题,或博客园. 题目一:如下表所示,现需要按照收款员统计收款和退款合计金额. 实现结果需如下显示: 分析:想要的结果(记为表B)和源数据(记为表A)相比,有共同的列(收款员),不同的是表A的金

网易2017校招内推笔试练习卷编程题1--1019.数字黑洞20

给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到 一个新的数字.一直重复这样做,我们很快会停在有"数字黑洞"之称的6174,这个神奇的数字也叫Kaprekar常数. 例如,我们从6767开始,将得到 7766 - 6677 = 1089 9810 - 0189 = 9621 9621 - 1269 = 8352 8532 - 2358 = 6174 7641 - 1467 = 6174 ... ... 现给

网易2017校招内推笔试练习卷编程题2--出专辑

你作为一名出道的歌手终于要出自己的第一份专辑了,你计划收录 n 首歌而且每首歌的长度都是 s 秒,每首歌必须完整地收录于一张 CD 当中.每张 CD 的容量长度都是 L 秒,而且你至少得保证同一张 CD 内相邻两首歌中间至少要隔 1 秒.为了辟邪,你决定任意一张 CD 内的歌数不能被 13 这个数字整除,那么请问你出这张专辑至少需要多少张 CD ? 输入描述: 每组测试用例仅包含一组数据,每组数据第一行为三个正整数 n, s, L. 保证 n ≤ 100 , s ≤ L ≤ 10000 输出描述

200道历年逻辑推理真题详解

200道历年逻辑推理真题详解 01.粮食可以在收割前在期货市场进行交易.如果预测谷物产量不足,谷物期货价格就会上升:如果预测谷物丰收,谷物期货价格就会下降.今天早上,气象学家们预测从明天开始谷物产区里会有非常需要的降雨.因为充分的潮湿对目前谷物的存活非常重要,所以今天的谷物期货价格会大幅下降. 下面哪个,如果正确,最严重地削弱了以上的观点? A.在关键的授粉阶段没有接受足够潮湿的谷物不会取得丰收. B.本季度谷物期货价格的波动比上季度更加剧烈. C.气象学家们预测的明天的降雨估计很可能会延伸到谷

php学习之道:WSDL详解(一)

WSDL文档使用web服务描述语言来定义服务. 文档包括逻辑(抽象)部分和具体部分. 抽象部分用于定义独立于实现的数据类型和消息,具体部分定义一个endpoint如何实现一个可以与外界进行交互的服务. 通常建议在写代码前定义WSDL文档和XML schema,但是这就要求对WSDL非常熟悉. 逻辑部分: 包括types,message以及portType元素.types元素中,xml schema用来定义组成消息的数据的结构.一定数量的消息元素用来定义服务所用消息的格式.portType元素包括

php学习之道:WSDL详解(三)

通过声明方式定义绑定(binding)属性 如果你在服务中采用SOAP binding,你可以使用JAX-WS来指定一定数量的属性binding.这些属性指定对应你在WSDL中指定的属性.某些设置,比如参数类型,可以约束你实现的方法,这些设置也影响声明的效用. @SOAPBinding声明,定义在javax.jws.soap.SOAPBinding接口中.它提供发布时的SOAP Binding细节.如果@SOAPBinding没有被指定,则用缺省的doc/literal SOAPBinding.

PHP Socket 编程过程详解

PHP Socket 编程过程详解 Socket用于进程间通信.进程间通信通常基于客户端—服务端模型.此时,客户端—服务端是可以彼此交互的应用程序.客户端和服务端之间的交互需要连接.Socket编程负责的就是为应用程序之间建立可进行交互的连接. 在本文中,我们将学习如何用PHP创建一个简单的客户端—服务端.我们还将学习如何客户端应用程序如何发送消息到服务端,以及如何从服务端接受消息. 使用代码 目的:开发一个客户端用于发送string消息到服务端,服务端将相同的信息反转后返回给客户端. PHP服

php学习之道:WSDL详解(二)

3.定义服务使用的逻辑消息 当服务的操作被调用时,服务被定义为消息交换.在wsdl文档中,这些消息被定义message元素.这些消息由称之为part元素的部分组成. 一个服务的操作,通过指定逻辑消息的方式来定义.当操作被调用时,逻辑消息被交换.(也就是说,逻辑消息代表了服务的操作)这些逻辑消息,将在网络上传输的数据定义为xml文档.他包含了所有的参数,这些参数是方法调用的一部分.(也就是说,逻辑消息里的参数,是操作对应方法的参数集合) 消息和参数列表:每一个被服务暴露的操作能且仅能有一个输入消息