目的是抛砖引玉,直接抄骗别人也是骗自己。
题目描述
C函数支持对字符串进行多种操作,这里我们要实现一个新的操作,循环移动某字符串.以字符串”ABCD”为例,循环右移一位字符串变成”DABC”; 但是如果是循环左移一位就变成了”BCDA”.循环右移N位就是连续N次循环右移一位, 循环左移N位就是连续N次循环左移一位.
输入
输入由多个测试(不超过15)用例组成.每个测试用例包含两行, 第一行包含一个长度不超过100的字符串(不含空格)以及一个整数C(1<=C<=10), C表示循环移位操作的数目. 第二行由C个字符串组成,字符串之间用空格分开,每一个字符串都是一个字符后面跟一个整数(范围为0-100000),字符为L或R,表示循环左移或循环右移。例如“L100”表示循环左移100位。
输出
对于每一个测试用例,输出C次操作后的字符串,每个用例输出占据一行。
样例输入 Copy
ABCD 1 L2 ABCD 2 R2 L2
样例输出 Copy
CDAB ABCD
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
char x[10000]= {'\0'};
char change[100]= {'\0'};
void left(char x[],int n,int len)
{
int i,ci;
for(i=0; i<n; i++)
{
for(ci=0; ci<len-1; ci++)
{
char temp=x[ci];
x[ci]=x[ci+1];
x[ci+1]=temp;
}
}
}
void right(char x[],int n,int len)
{
int i,ci;
for(i=0; i<n; i++)
{
for(ci=len-1; ci>0; ci--)
{
char temp=x[ci];
x[ci]=x[ci-1];
x[ci-1]=temp;
}
}
}
int shu(char x)
{
if(x=='0')return 0;
if(x=='1')return 1;
if(x=='2')return 2;
if(x=='3')return 3;
if(x=='4')return 4;
if(x=='5')return 5;
if(x=='6')return 6;
if(x=='7')return 7;
if(x=='8')return 8;
if(x=='9')return 9;
}
int main()
{
int n;
while((scanf("%s%d",x,&n))!=EOF)
{
int len=strlen(x);
int i;
for(i=0; i<n; i++)
{
int change1;
int y;
//change1=getchar();
scanf(" %c%d",&change[0],&y);
int ture=y%len;
if(change[0]=='L')left(x,ture,len);
if(change[0]=='R')right(x,ture,len);
}
puts(x);
}
return 0;
}