zoukankan      html  css  js  c++  java
  • Codeforces Round #590 (Div. 3) codeforces打完补题

    https://codeforces.com/contest/1234/problem/D

    写了个巨蠢的线段树(不愧是垃圾),有必要提醒下自己这种题怎么做

    #include<iostream>
    #include<cstdio>
    #include<string>
    #include<set>
    #include<algorithm>
    using namespace std;
    const int maxn = 32;
    set<int> st[maxn];
    int main()
    {
        string words;
        cin>>words;
        words = '.' + words;
        int len = words.size() - 1;
        for(int i=1;i<=len;++i)
            st[words[i]-'a'].insert(i);
        int q,cmd,pos,l,r;
        char ch;  scanf("%d",&q);
        for(int k=0;k!=q;++k)
        {
            scanf("%d",&cmd);
            if(cmd==1)
            {
                scanf("%d",&pos);
                getchar();
                scanf("%c",&ch);
                st[words[pos]-'a'].erase(pos);
                words[pos] = ch;
                st[words[pos]-'a'].insert(pos);
            }else{
                int ans = 0;
                scanf("%d%d",&l,&r);
                for(int i=0;i!=26;++i)
                {
                    auto it = st[i].lower_bound(l);//MDZZ 再也不直接用algorithm的二分了,容器内的快多了,佛了
                    if(it == st[i].end())
                        continue;//找到大于等于l开始的字符,因为不重复,所以只需要找出一个就好了(ORZ)
                    int x = *it;
                    if(x <= r)
                        ++ans;
                }
                cout<<ans<<'
    ';        
            }
        }      
    }
    

    https://codeforces.com/contest/1234/problem/C

     简单实现

    #include<bits/stdc++.h>
    using namespace std;
    const int maxn = 2e5 + 32;
    int dp[3][maxn];
     int q,n;
    void solve()
    {
        int l = 1,r = 1,k = 1;
        while(1)
        {
            if(l>n)
            {
                if(r==2)
                {
                    cout<<"YES"<<'
    ';
                    return;
                }
                cout<<"NO"<<'
    ';
                return;
            }
            if(k==1&&dp[r][l]==1)
            {++l;}else 
            if(k==1&&dp[r][l]==2)
            {r = 3 - r; k = 2;}else
            {
                if(dp[r][l]!=2)
                {
                    cout<<"NO"<<'
    ';
                    return;
                }else{
                    ++l;
                    k = 1;
                }
            } 
        }
    }
    int main()
    {
        ios::sync_with_stdio(false); cin.tie(0),cout.tie(0);
        cin >> q;
        while(q--)
        {
            cin >> n;   char ch;
            for(int i=1;i<=2;++i)
            {
                for(int j=1;j<=n;++j)
                {
                    cin>>ch;
                    if(ch=='1'||ch=='2')
                        dp[i][j] = 1;
                    else
                        dp[i][j] = 2;
                }
            }
            solve();
        }
    }
    

      

     垃圾如我,哭啦

    不怕万人阻挡,只怕自己投降。
  • 相关阅读:
    三者最大实例分析
    Python eval函数
    Linux查看某个进程的线程
    将列表传递给函数
    二十四、二进制日志截取与恢复
    二十三、二进制日志事件
    二十二、二进制日志记录方式
    二十一、二进制日志介绍
    二十、错误日志
    十九、InnoDB核心参数
  • 原文地址:https://www.cnblogs.com/newstartCY/p/11616651.html
Copyright © 2011-2022 走看看