java试题

本文介绍了一种使用Java实现的方法,用于从给定字符串中找到最长的连续数字串,并返回其长度。通过正则表达式匹配所有数字串,然后记录最长的数字串及其长度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在字符串中找出连续最长的数字串,并返回最长数字串长度;如果最长数字串长度相同,则返回最后一个;

代码:

import java.util.HashMap;
import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class GetNum {
	public void longNum(String str) {
		Map<Integer, String> map = new HashMap<Integer, String>();
		// 验证规则
		String regEx = "\\d+";
		// 编译正则表达式
		Pattern pattern = Pattern.compile(regEx);
		Matcher matcher = pattern.matcher(str);
		int temp = 0;
		while (matcher.find()) {
			String s = matcher.group();
			map.put(s.length(), s);
			temp = s.length() > temp ? s.length() : temp ;
		}
		System.out.println((map.get(temp) == null ? " " :  map.get(temp))+ "," + temp);
	}

	public static void main(String[] args) {
		long st = System.nanoTime();
		GetNum gn = new GetNum();
		gn.longNum("asdf1234;kjk42kk3421jj232aa");
		long end = System.nanoTime();
		System.out.println(end - st);
	}
}

运行结果:

3421,4

1599991

最后一个打印的是执行所需纳秒,还是不理想,希望大神提供更好的方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值