2020牛客暑期多校训练营(第三场)B——Classical String Problem

题目链接

在这里插入图片描述
在这里插入图片描述
题意:

给你一个字符串,下标1开头,q组询问,每一组有一个字符op,一个数字x,op='A’时,输出当前字符串第x个字符,op='M’时,如果x>0,把字符串最左边的x个字符放到字符串右边,x<0,把字符串最右边|x|个字符放到字符串左边。

思路分析:

定义个pos标记,最开始pos在0的位置,不管怎么移动,这个字符串始终是一个环,所以我们每次移动可以看做这个指针在移动,最后输出相应结果就行。
在这里插入图片描述

在这里插入图片描述

#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<string>
using namespace std;
char s[2005001];
int main()
{
   scanf("%s",s);
    int len=strlen(s),l=0;
    int q;
    scanf("%d",&q);
    while(q--)
    {
        char op;int x;
        scanf(" %c %d",&op,&x);
        if(op=='A')
             cout<<s[(x+len+l-1)%len]<<'\n';
         //   cout<<s[(x+len+l-1)%len]<<endl;  endl 比 \n 效率慢多了,会卡时间
        else
        {
            l=(l+x+len)%len;
        }
    }
    return 0;  
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值