题解 | #在字符串中找出连续最长的数字串#

在字符串中找出连续最长的数字串

http://www.nowcoder.com/practice/2c81f88ecd5a4cc395b5308a99afbbec

用一个ArrayList记录目前为止最长数字字符串的起点, 用一个int记录目前为止最长数字字符串长度, 就可以通过一次遍历来找出结果.

import java.util.*;

public class Main{
    public static void main(String[] args){
        Scanner in = new Scanner(System.in);
        while(in.hasNextLine()){
            String str = in.nextLine();
            System.out.println( find_longest_numeric(str) );

        }
    }

    public static String find_longest_numeric(String str){
        str += ".";//给str加一个结尾符号
        ArrayList<Integer> startIndex_list = new ArrayList<Integer>(); //最长的数字字符串的起点(>=1)
        int max_len = 0;//最长的数字字符串的长度
        int len = 0;//当前数字字符串的长度
        int start_index = -1;//当前数字字符串的起点
        for(int i=0;i<str.length();i++){
            char cr = str.charAt(i);
            if(Character.isDigit(cr)){// 这一位是数字
                len++;
                if(len==1){//如果这是数字字符串的第一位,更新 start_index 为 i
                    start_index = i;
                }
            }else{// 这一位不是数字
                if(len > max_len){//如果这个数字字符串的长度比 max_len 记录要长
                    max_len = len;//更新 max_len
                    startIndex_list.clear();//删除 ArrayList 以前的所有记录
                    startIndex_list.add(start_index);//添加这一数字字符串的起点
                }else if(len == max_len){//如果这个数字字符串的长度和 max_len 记录相同
                    startIndex_list.add(start_index);//添加这一数字字符串的起点
                }
                //重置 数字字符串长度变量len 和 数字字符串起点start_index
                len = 0;
                start_index = -1;
            }
        }

        //整理并返回结果
        String result = "";
        for(int index : startIndex_list ){
            result+=str.substring(index, index+max_len);
        }
        result = result + "," + max_len;
        return result;

    }

}
全部评论

相关推荐

1.第一种人呢以92和计算机强双非(四邮四电)偏多,这种人呢,喜欢把自己的学校称为“大专”,极力在交流时贬低自己的学历,放大自己学历的缺点(如牛客经典贴,双非秋招oc美团,点开发现是985硕士🤣🤣🤣),说的自己学校好像比双非认可度还低,好像这样才能突出自己多么牛逼,克服了多少困难,技术有多强,但你要是说想双非考研去他们学校,他们又要狠狠打压你,告诉考他们学校多难了🤣🤣🤣。从92到大厂明明是证明自己一直优秀的一条路,你不走,你非要故意恶心自己也恶心别人,何必呢?2.第二种人以像我一样的双非同学偏多,大多学历比较低,可能又带有中大厂实习。他们会在你交流的时候,十分刻意的强调自己是弱双非或者学院本,再不经意透露自己在某某大厂实习。等着群聊里响起“原来是xx(大厂名字)✌🏻啊,给你跪了😭”,他们便心满意足了。不用反驳,因为我之前也是这种人,现在也有这种倾向😆😆😆。3.第三种人更是神人,跟这种人交流时,你会觉得对方已经被美国植入芯片控制了,张嘴闭嘴只有膜膜膜,羡慕羡慕羡慕。上到拿到大厂offer,下到喝一杯奶茶,他们都说羡慕。不知道他们的生活过得有多么悲惨,连喝杯饮料都到了羡慕的地步🤣🤣🤣。天天就是在群里面互相吹捧,互相羡慕,不知道交流起来有什么意思。4.第四种人则是第一种人的对立面,我有时候觉得是第四种人太多才会导致第一种人的出现。这种人天生带着对92的恨。仿佛学计算机没有拿到offer全是92导致的。他们是小说里被陷害的白莲花女主,92则是夺走他们人生的恶毒女配。在他们的眼中,他们的技术要比92好一百倍,但是所有企业都识别不了他们这匹千里马。实际自己从来没想过,在ai与辅导课程普及的当日,所谓的计算机,早已经没有了任何的技术壁垒,否则也不会有那么人转码了😂。这是那天回家路上发抖音的,讨论不少,有赞同有不赞同的,其实有时候也在想自己言论是否偏激。今天遇到朋友问我好久没更新牛客了,就搬了上去。其实很简单,加了交流群之后,发现交流的质量参差不齐,有些实在言之无物,想了想自己也会有这样的问题。自己也在建交流群,希望能避免这样的现象吧
wu970:交流群不就是一群人互相装逼和加装谦虚吗
如何排解工作中的焦虑
点赞 评论 收藏
分享
01-02 18:04
厦门大学 Java
码农索隆:想回家的心 +10000
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务