zoukankan      html  css  js  c++  java
  • 苦逼的单身狗(玄乎的尺取大法)

    链接:https://www.nowcoder.com/acm/contest/27/F

    双11又到了,小Z依然只是一只单身狗,对此他是如此的苦恼又无可奈何。

    为了在这一天脱单小Z决定向女神表白,但性格腼腆的小Z决定隐晦一点,截取一段包含'L'、'O'、'V'、'E'的英文。(顺序不限)

    小Z想起之前小D送给他一本英文书,决定在这里面截取一段话,小Z发现有好多种方案来截取这段话。

    你能知道小Z能有多少种方案截取这段话么?

    为了简化问题,英文文本讲不会出现空格、换行、标点符号及只有大写的情况。

    输入描述:

    本题有T组数据。
    对于每组数据只有一行文本。
    1≤T≤20
    1≤文本长度≤100000

    输出描述:

    输出结果,并换行。

    示例1

    输入

    3
    ILOVEACM
    LOVELOVE
    ALBECVOD

    输出

    8
    15
    4
    分析:我们可以发现当区间满足条件的时候,这个区间的贡献为(n-en+1),依据这点可以减少时间复杂度,只要搜索道满足条件即可,
    不满足条件我就en指针右移动,满足条件st指针我就左移动同时记录可能性(n-en+1),在移动的过程中记录出现字母的次数,从而达到查看区间是否满足条件,结束条件是en<=n(字符串的个数)
    #include<stdio.h>
    #include<string.h>
    #include<map>
    #define ll long long
    using namespace std;
    map<char,ll>mp;
    char ch[110000];
    int main()
    {
        int t;
        scanf("%d",&t);
        while(t--)
        {
            for(int i=0 ; i<=26 ; i++)
                mp['A'+i]=0;
            ll ans=0;
            getchar();
            scanf("%s",ch);
            int n=strlen(ch);
            int st=0,en=0;
    
            while(en<=n)
            {
    
                if(mp['L']==0)
                {
                    mp[ch[en]]++;
                    en++;
    
                }
    
                else if(mp['O']==0)
                {
    
                     mp[ch[en]]++;
                     en++;
                }
    
                else if(mp['V']==0)
                {
    
                    mp[ch[en]]++;
                    en++;
                }
    
                else if(mp['E']==0)
                {
    
                        mp[ch[en]]++;
                        en++;
                }
    
                else
                {
                    ans+=n-en+1;
                    mp[ch[st]]--;
                    st++;
                }
            }
            printf("%lld
    ",ans);
        }
    }
    View Code
  • 相关阅读:
    《Excel效率手册:早做完,不加班》
    《“胡”说IC——菜鸟工程师完美进阶》
    《UNIX环境高级编程(第3版)》
    《学习R》
    《Netty权威指南》
    《啊哈!算法》
    《流程的永恒之道》
    《算法帝国》
    Guava-Optional可空类型
    guava之Joiner 和 Splitter
  • 原文地址:https://www.cnblogs.com/shuaihui520/p/9025211.html
Copyright © 2011-2022 走看看