题目描述
给定一个字符串,只包含字母和数字,按要求找出字符串中的最长(连续)子串的长度,字符串本身是其最长的子串,子串要求:
1、 只包含1个字母(a~z, A~Z),其余必须是数字;
2、 字母可以在子串中的任意位置;
如果找不到满足要求的子串,如全是字母或全是数字,则返回-1。
输入描述
字符串(只包含字母和数字)
输出描述
子串的长度
用例
输入 abC124ACb
输出 4
说明 满足条件的最长子串是C124或者124A,长度都是4
输入 a5
输出 2
说明 字符串自身就是满足条件的子串,长度为2
输入 aBB9
输出 2
说明 满足条件的子串为B9,长度为2
输入 abcdef
输出 -1
说明 没有满足要求的子串,返回-1
解题思路:
- 遍历字符串,记录当前连续数字和字母的数量;
- 如果遇到一个字母,判断前面的连续数字数量是否大于等于1,如果满足条件,更新最长子串长度;
- 如果遇到一个数字,判断前面的连续字母数量是否大于等于1,如果满足条件,更新最长子串长度;
- 遍历结束后,返回最长子串长度。