字符串右移
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
1
-
描述
-
LZQ最近迷上了字符串,于是他有一个问题想考你,聪明的你一定知道答案。问题如下:给你一个字符串,让你对其进行向右移动K次,输出新的字符串。
-
输入
-
输入数据有多组,每组有一个字符串STR与一个数字K,表示对字符串STR向右移动K位。
输出
- 输出新的字符串STR1. 样例输入
-
abcd1234 4 sdfe123f 10
样例输出
-
1234abcd 3fsdfe12
来源
- 原创 上传者
思想 :abcde1234 4
1234abcde 是不是很像先输出1234 再输出abcde
由数组角标分析 是从a[5]开始输出到结尾 再从a[0]输出到a[4]
当步数大于字符串长度时 步数n=n%l(字符串长度);
为了方便起见 直接把n=n%10进行了操作
#include<stdio.h> #include<string.h> int main() { char s[100]; int n; while(~scanf("%s%d",s,&n)) { int l=strlen(s); n=n%l; printf("%s",s+l-n); for(int j=0;j<l-n;j++) printf("%c",s[j]); puts(""); } return 0; }
-
输入数据有多组,每组有一个字符串STR与一个数字K,表示对字符串STR向右移动K位。