程序员

SDUT 2021 Spring Individual Contest(for 20) - 12 补题

作者:admin 2021-04-14 我要评论

H题Genta Game 题意首先给定n和mn为字符串长度接着给定字符串m次操作问m次操作中有多少次会出现回文串 思路因为给的数据范围是1e5,所以时间复杂度应该控制在Onlo...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

H题Genta Game
题意:首先给定n和m,n为字符串长度,接着给定字符串,m次操作,问m次操作中有多少次会出现回文串
思路:因为给的数据范围是1e5,所以时间复杂度应该控制在O(nlogn)以内。首先先把给定的字符串预处理一下,查询字符串中有多少个不回文的部分,之后的每一次操作中,操作结束时判断不回文的部分是否为0,如果是,结果加一。

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+10;
char a[N];
int main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    int t;
    cin>>t;
    while(t--)
    {
        int res=0;
        int ans=0;
        int n,m;
        cin>>n>>m;
        cin>>a;
        int len=strlen(a);
        for(int i=0,j=len-1;i<=j;i++,j--)
        {
            if(a[i]!=a[j])
            res++;
        }   
        for(int i=0;i<m;i++)
        {
            int x;
            char c;
            cin>>x>>c;
            if(n%2==1&&x==n/2+1&&res==0)//特殊情况判定
            ans++;
            x--;
            if(a[x]!=a[n-1-x])
            {
                if(a[n-1-x]==c)
                {
                    res--;
                }
            }
            else
            {
                if(a[x]!=c)
                {
                    res++;
                }
            }
            a[x]=c;
            if(res==0)
            ans++;
        }
        cout<<ans<<endl;
    }
    return 0;
}
;原文链接:https://blog.csdn.net/weixin_51768569/article/details/115419508

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 四两拨千斤——你不知道的VScode编码Ty

    四两拨千斤——你不知道的VScode编码Ty

  • 我是如何在 Vue 项目中做代码分割的

    我是如何在 Vue 项目中做代码分割的

  • position:sticky 粘性定位的几种巧妙应

    position:sticky 粘性定位的几种巧妙应

  • 从零到一搭建React组件库

    从零到一搭建React组件库

腾讯云代理商
海外云服务器