[C/C++]输出指定长度的子串 - 2019校招编程刷题
参考链接
题目描述
给定一个字符串,输出所有指定长度为n的子串,没有则输出-1
输入描述
输入第一行一个字符串,如:“1234567890”
输入第二行一个数字是n,如5
输出描述
输出所有长度为n的子串,如“12345”,“23456”,“34567”,“45678”,“56789”
输入例子1:
123456789
5
输出例子1:
12345 23456 34567 45678 56789
思路:
- 重点就是字符串的切分,
substr()
函数 - 首先,判断一下要求的长度n是否超过字符串的长度。如果超过直接输出-1,如果没超过就一个个输出即可。
Just show my code
代码(c++/c)
#include<iostream>
#include<string.h>
using namespace std;
int main(){
string s;
cin >>s;
int n;
cin>>n;
if( n <=s.length(){
for(int i = 0 ; i < s.length()-n + 1;i++){
cout<<s.substr(i,n)<<" ";
}
}
else{
cout<<"-1"<<endl;
}
return 0;
}
如果我的文章能帮你节约20秒,就请你为我的文章点个赞吧!