PTA 基础编程题 7-31 字符串循环左移 (20 point(s))

7-31 字符串循环左移 (20 point(s))

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

输入格式:

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

输出格式:

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

输入样例:

Hello World!
2

输出样例:

llo World!He

思路:

因为左移n个,先取模,因为假如n大于字符串个数,无论字符串循环多少次它本身,顺序是不变的,先输出n后的字符串,再输出之前的,左移就完成了

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

你可能感兴趣的:(PTA)