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

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

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

java:
1、非数字全部用空格代替;
2、分割空格得到每组不同的数字集合;
3、求出数字集长度最大值;
4、依次遍历,若为最大值则依次输出;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        while (sc.hasNext()) {
            String str = sc.nextLine();
            StringBuffer sb = new StringBuffer();
            for (int i = 0; i < str.length(); i++) {
                char c = str.charAt(i);
                if (!Character.isDigit(c)) {
                    sb.append(" ");
                } else {
                    sb.append(c);
                }
            }
            String[] arr = sb.toString().split(" ");
            int max = 0;
            for (int i = 1; i < arr.length; i++) {
                if (arr[i - 1].length() < arr[i].length()) {
                    max = max > arr[i].length() ? max : arr[i].length();
                }
            }
            for (int i = 0; i < arr.length; i++) {
                if (arr[i].length() == max) {
                    System.out.print(arr[i]);
                }
            }
            System.out.println("," + max);
        }
    }
}


#小白的技术进阶日记#
全部评论

相关推荐

不愿透露姓名的神秘牛友
06-27 20:55
点赞 评论 收藏
分享
05-07 19:10
已编辑
中国科学技术大学 C++
silly01:现在先去 momenta,8-9月去鹅找日常实习,八股文算法背好了你这随便进。不过建议补充一下后端知识,MySQL、Redis看下八股,再补个6824,加点go后台的技术栈,9月随便进大厂。CPP后端只能来WXG
点赞 评论 收藏
分享
点赞 评论 收藏
分享
机械打工仔:第一位颇有孟德之志
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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