题目
给出一个字符串作为输入,找出其中最长的连续数字串并返回其长度和起始index。如果存在长度相同的连续数字串,返回最后一个连续数字串。如果没有,返回0和0。
Analysis
对于这道题目,首先我们需要进一步缩小题目范围。题目中并没有给出字符串中的数字都是什么数字。比如是否包含负数,是否包含小数等。因此简单起见,我们假设该输入字符串中只包含正整数。且假设输入字符串中没有空格。
设输入字符串的长度为n。
从Best Conceivable Time的角度考虑,这道题的时间复杂度至少为O(n)。也就是说,对于这道题而言,我们至少需要遍历整个输入的字符串一次才能得出答案。因此在时间复杂度角度考虑,我们并没有多少优化的空间。
从空间复杂度的角度考虑,brute-force解法比较直观,就是遍历一遍整个输入字符串,找出并记录其中所有的连续数字子串。然后在所有被记录的数字子串中找出最长的那个。因为题目要求有多个最长子串时返回最后一个,所以我们只需要返回最后一个被记录的最长子串即可。这个方法最坏情况下需要记录整个输入字符串。所以空间复杂度为O(n)。
具体实现如下:
public class LongestNumberSubstring {
public static int[] findLongestNumSubstring(String input) {
// If the string is empty, return [0,

给定一个字符串,找出最长的连续数字子串的长度和起始index。假设字符串只包含正整数,没有空格。分析了题目时间复杂度和空间复杂度,并提供了优化的2 pointers解法。
最低0.47元/天 解锁文章
1491





