循环移动

 

目的是抛砖引玉,直接抄骗别人也是骗自己。

题目描述

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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值