zoukankan      html  css  js  c++  java
  • 哈希URAL 1941

    A - Scary Martian Word
    Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u

    Description

    There are different superstitions on different planets. Martians laugh at Earthlings suffering Triskaidekaphobia and Hexakosioihexekontahexaphobia. And Earthlings make jokes on the fact that there is a scary word in Martian language. Martians are not only afraid of the word itself, but also of all the words that are obtained by rearrangement of letters in this word.
    The Martian alphabet has 729 000 letters. Correspondent Ovchinnikov, who lives on Mars and studies Martian language, represents Martian letters as triplets of symbols with ASCII codes from 33 to 122. He has recently written a book about life and culture on Mars. Before sending the book into press Ovchinnikov wants to count the number of substrings in the text of the book which are frightening for Martians.

    Input

    The first line contains the scary Martian word, consisting of at most 8 000 Martian letters. The second line contains the text of Ovchinnikov's book, which is at most 500 000 Martian letters long. Both the scary word and the text of the book contain at least one letter. Every Martian letter is represented by the triplet of symbols with ASCII codes from 33 to 122, each letter separated from the next one by a whitespace.

    Output

    Output the number of substrings in the book by correspondent Ovchinnikov, which are frightening for Martians.

    Sample Input

    inputoutput
    aaa bbb ccc
    aaa aaa bbb ccc aaa zzz aaa bbb ccc
    
    3
    

    Notes

    Two substrings “aaa bbb ccc” (starting from the second and the seventh positions in the text) and a substring “bbb ccc aaa” are scary for the Martians.
     



    #include<stdio.h>
    #include<string.h>
    #include<iostream>
    #include<algorithm>
    using namespace std;
    const int maxn=127;
    int cur[maxn*maxn*maxn];
    int hash[maxn*maxn*maxn];
     char s[4];
    int change(char *s){
       int  res=0;
       for(int i=0;i<3;i++){
          res=maxn*res+s[i];
       }
       return res;
    }
    int h[550000];
    int main(){
         char c;
         int len=0;
         while(scanf("%s",s)!=EOF){
            int temp=change(s);
            hash[temp]++;
               len++;
            c=getchar();
    
            if(c=='
    ')
                break;
         }
         int ans=0;
         int cnt=0;
          for(int i=0;;i++){
               scanf("%s",s);
                int d=change(s);
                h[i]=d;
              if(cur[d]<hash[d])
                cnt++;
              cur[d]++;
              if(i>=len){
                    d=h[i-len];
                   if(cur[d]<=hash[d])
                     cnt--;
                cur[d]--;
              }
              if(cnt==len)
                    ans++;
                c=getchar();
              if(c=='
    ')
                break;
         }
         printf("%d
    ",ans);
         return 0;
    }

  • 相关阅读:
    JavaScript中的事件
    JavaScript中的String
    和Java相关的一些好文章(不定期更新)
    大端序小端序
    C语言中const的正确用法
    skynet源码分析之网络层——Lua层介绍
    skynet源码分析之网络层——底层介绍
    skynet源码分析之定时器skynet_timer.c
    skynet源码分析之lua层消息处理
    skynet源码分析之snlua服务的启动流程(二)
  • 原文地址:https://www.cnblogs.com/13224ACMer/p/4686955.html
Copyright © 2011-2022 走看看