题目
读入一个字符串str,输出字符串str中的连续最长的数字串
输入描述:
个测试输入包含1个测试用例,一个字符串str,长度不超过255。
输出描述:
在一行内输出str中里连续最长的数字串。
示例1
输入
abcd12345ed125ss123456789
输出
123456789
思路
从字符串的0号位置开始寻找数字,开始设i=0,j=0。
先找第一个数字,i不断后移,遇到数字,则j=i,j为数字的最高位,i继续后移直到字符不是数字位置;
用len记录这个数字的位数;
通过string.substr()获取该子串(数字);
字符串其余数字重复以上操作即可。
解答
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s;
cout<<"input:s="<<endl;
cin >> s;
int len_s = s.size();
int i=0, j=0;
string s0="";
string maxLen;
while (i < len_s)
{
if (s[i] >= '0'&& s[i] <= '9')
{
j = i;
int len = 0;//数字的位数
while (s[i] >= '0'&& s[i] <= '9')
{
i++;
len++;
}
s0 = s.substr(j, len);//获取子串
if(s0.length()>=maxLen.length()){
maxLen=s0;
}
}
else
{
i++;
}
}
cout<<"output:"<<maxLen<<endl;
return 0;
}