51nod 1127 最短的包含字符串

Posted 8023spz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了51nod 1127 最短的包含字符串相关的知识,希望对你有一定的参考价值。

给出一个字符串,求该字符串的一个子串s,s包含A-Z中的全部字母,并且s是所有符合条件的子串中最短的,输出s的长度。如果给出的字符串中并不包括A-Z中的全部字母,则输出No Solution。
 
Input
第1行,1个字符串。字符串的长度 <= 100000。
Output
输出包含A-Z的最短子串s的长度。如果没有符合条件的子串,则输出No Solution。
Input示例
BVCABCDEFFGHIJKLMMNOPQRSTUVWXZYZZ
Output示例
28

尺取。
代码:
#include <iostream>
#include <cstdio>
#include <algorithm>
#define MAX 100001
using namespace std;

char s[MAX];
int m = MAX;
int main() {
    int head = 0,tail = 0,c = 0,num[26] = {0};
    scanf("%s",s);
    while(s[tail] || c == 26) {
        if(c < 26) {
            int d = s[tail ++] - A;
            if(!num[d]) c ++;
            num[d] ++;
        }
        else {
            m = min(m,tail - head);
            int d = s[head ++] - A;
            if(num[d] == 1) c --;
            num[d] --;
        }
    }
    if(m != MAX)printf("%d
",m);
    else printf("No Solution
");
}

 

以上是关于51nod 1127 最短的包含字符串的主要内容,如果未能解决你的问题,请参考以下文章

51nod 1127 最短的包含字符串

51Nod1127 最短的包含字符串

[51NOD1127]最短的包含字符串(尺取法)

51nod1127(尺取法)

51NOD 1385凑数字(找规律?)

51 Nod 1350 斐波那契表示