zoukankan      html  css  js  c++  java
  • Codeforces 113B

    题目链接

    B. Petr#
    time limit per test
    2 seconds
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Long ago, when Petya was a schoolboy, he was very much interested in the Petr# language grammar. During one lesson Petya got interested in the following question: how many different continuous substrings starting with the sbegin and ending with the send (it is possible sbegin = send), the given string t has. Substrings are different if and only if their contents aren't equal, their positions of occurence don't matter. Petya wasn't quite good at math, that's why he couldn't count this number. Help him!

    Input

    The input file consists of three lines. The first line contains string t. The second and the third lines contain the sbegin and sendidentificators, correspondingly. All three lines are non-empty strings consisting of lowercase Latin letters. The length of each string doesn't exceed 2000 characters.

    Output

    Output the only number — the amount of different substrings of t that start with sbegin and end with send.

    Sample test(s)
    input
    round
    ro
    ou
    output
    1
    input
    codeforces
    code
    forca
    output
    0
    input
    abababab
    a
    b
    output
    4
    input
    aba
    ab
    ba
    output
    1
    Note

    In the third sample there are four appropriate different substrings. They are: ab, abab, ababab, abababab.

    In the fourth sample identificators intersect.

    思路:首先在字符串t中找到sbegin和send的位置, 也就是下面代码中两个数组flag1和flag2的作用。

    对于每个sbegin的出现位置,向后扫一遍t,因为sbegin和send可以重合,所以要求被加入ans 中的字符串长度要不小于sbegin和send的最小长度。

    只需要加入字符串的hash值, 最后去重即可。

    这里,用到的两个stl函数, 一个是substr(begin, length), 第一个参数为字符串的起始地址,第二个参数为要去字串的长度。

    第二个函数是unique函数, unique(begin, end, compare), 这里第三个参数compare是比较函数,一般的类型比较都可以省略,

    unique用来将相邻的重复元素移至数组的末尾,而不是直接删除,其返回值为指向第一个出现重复的元素的迭代器,并且一般和sort配合使用。

     Accepted Code:

     1 /*************************************************************************
     2     > File Name: 113B.cpp
     3     > Author: Stomach_ache
     4     > Mail: sudaweitong@gmail.com
     5     > Created Time: 2014年07月18日 星期五 22时08分53秒
     6     > Propose: 
     7  ************************************************************************/
     8 #include <set>
     9 #include <cmath>
    10 #include <string>
    11 #include <cstdio>
    12 #include <vector>
    13 #include <fstream>
    14 #include <cstring>
    15 #include <iostream>
    16 #include <algorithm>
    17 using namespace std;
    18 
    19 string t, b, e;
    20 int flag1[2002], flag2[2002];
    21 int len1, len2, len3;
    22 typedef unsigned long long ull;
    23 vector<ull> ans;
    24 
    25 void
    26 solve(int x) {
    27     ull tt = 0;
    28       for (int i = x; i < len1; i++) {
    29           tt = tt * 31 + t[i];
    30         if (flag2[i] == 1 && i-x+1 >= max(len2, len3)) ans.push_back(tt);
    31     }
    32 }
    33 
    34 int
    35 main(void) {
    36         cin >> t;
    37           cin >> b;
    38         cin >> e;
    39         len1 = (int)t.size();
    40         len2 = (int)b.size();
    41         len3 = (int)e.size();
    42         int maxl = max(len2, len3);
    43         for (int i = 0; i < len1; i++) {
    44               if (t.substr(i, len2) == b) flag1[i] = 1;
    45             if (t.substr(i, len3) == e) flag2[i+len3-1] = 1; 
    46         }
    47         for (int i = 0; i < len1; i++) if (flag1[i]) {
    48               solve(i);
    49         }
    50         sort(ans.begin(), ans.end());
    51         ans.resize(unique(ans.begin(), ans.end())-ans.begin());
    52         printf("%d
    ", ans.size());
    53 
    54     return 0;
    55 }
  • 相关阅读:
    原生JS之温故而知新(一)
    jQuery版本问题
    AngularJs我的学习整理(不定时修改)
    Js事件处理程序跨浏览器
    AngularJs的关于路由问题
    很棒的十句话,分享给大家。
    一个人为什么要努力?
    春熙路。
    成都
    springboot 使用mybatis-generator自动生成代码
  • 原文地址:https://www.cnblogs.com/Stomach-ache/p/3854679.html
Copyright © 2011-2022 走看看