题目描述
给定一个字符串,只包含字母和数字,按要求找出字符串中的最长(连续)子串的长度,
字符串本身是其最长的子串,子串要求:
1、 只包含1个字母(a~z, A~Z),其余必须是数字;
2、 字母可以在子串中的任意位置;
如果找不到满足要求的子串,如全是字母或全是数字,则返回-1。
输入描述
字符串(只包含字母和数字)
输出描述
子串的长度
用例1
输入
abC124ACb
输出
4
说明
满足条件的最长子串是C124或者124A,长度都是4
用例2
输入
a5
输出
2
解题思路
1.用滑动窗口法,设置左右指针,右指针一直往右移动,满足只要一个字母要求时
求最大长度
2.窗口含有字母大于1时,右移动左指针,直到含义字母为1
考点
滑动窗口
【华为OD机试】求满足条件的最长子串的长度(C++ Python Java)2023 B卷
最新推荐文章于 2024-06-25 16:24:10 发布
这是一道华为在线测评(OD)的算法题,要求找到只包含一个字母和多个数字的最长连续子串长度。输入为字母和数字组成的字符串,输出符合条件的最长子串长度。当不存在符合条件的子串时,返回-1。给出的解题思路是使用滑动窗口法,通过左右指针动态调整窗口大小,确保窗口内始终只有一个字母。
摘要由CSDN通过智能技术生成