【C++】字符串循环左移(PTA)

题目描述
输入一个字符串和一个非负整数N,要求将字符串循环左移N次。

输入格式:
输入在第1行中给出一个不超过100个字符长度的、以回车结束的非空字符串;第2行给出非负整数N。

输出格式:
在一行中输出循环左移N次后的字符串。

输入样例:

Hello World!
2

输出样例:

llo World!He

我的代码

#include
#include 
using namespace std;
int main(){
	string s;
	int n;
	getline(cin,s);
	cin>>n;
	n=n%s.length();
	cout << s.substr(n) << s.substr(0,n);
} 

这个题之前做过类似的,我记着我是用字符数组做的,然后用for循环逐个输出,感觉做的过程并没有什么问题,但是输出的时候老是有一串乱码,不知道为什么。在网上搜索别人的答案,发现了一个C++中的substr函数,感觉超级好用,用这个函数代码变得非常简单,于是就果断地放弃了之前的,写完之后感觉真香。

sunstr函数用法
substr(string,start,end):从字符串string的start位置开始提取字符串。

#include
#include
using namespace std;

int main()
{
string s("12345asdf");
string a=s.substr(0,5);//获得字符串s中 从第0位开始的长度为5的字符串//默认时的长度为从开始位置到尾
cout<<a<<endl;

输出结果为

12345

你可能感兴趣的:(C++)