zoukankan      html  css  js  c++  java
  • hud 4455 Substrings 解题报告

    题意:给你一个序列 , 然后给你q个询问t,问这个序列中t个连续的子集中不同元素个数的和;

    解题思路:http://www.cnblogs.com/kuangbin/archive/2012/11/11/2765329.html

    解题代码:

    // File Name: c.c
    // Author: darkdream
    // Created Time: 2013年05月31日 星期五 18时14分34秒
    
    #include<stdio.h>
    #include<string.h>
    #include<stdlib.h>
    #include<time.h>
    #include<math.h>
    int a[1000010];
    int c[1000010];
    int b[1000010];
    int f[1000010];
    long long dp[1000010];
    int main(){
    
        //freopen("/home/plac/problem/input.txt","r",stdin);
        //freopen("/home/plac/problem/output.txt","w",stdout);
        int n ;
        while(scanf("%d",&n) != EOF,n)
        {  
            memset(dp,0,sizeof(dp));
            memset(a,0,sizeof(a));
            memset(c,0,sizeof(c));
            memset(b,0,sizeof(b));
            memset(f,0,sizeof(f));
            for(int i = 1;i <= n;i ++)
            {    scanf("%d",&a[i]);
            
                 c[i-f[a[i]]] ++;
                f[a[i]] = i ;
            }
            memset(f,0,sizeof(f));
            b[1] = 1;
            f[a[n]] = 1;
            for(int i = 2;i <= n;i ++)
            {
                if(f[a[n-i+1]] == 0)
                {
                    f[a[n-i+1]] = 1;
                    b[i] = b[i-1]+1;
                }
                else  b[i] = b[i-1];
            }
            dp[1] = n;
            int sum = n;
            for(int i = 2 ; i <= n; i ++)
            {
                dp[i] = dp[i-1] - b[i-1];
                sum-= c[i-1];
                dp[i]+= sum;
            }
            
            int q; 
            scanf("%d",&q);
            while(q--)
            {
                int temp;
                scanf("%d",&temp);
                printf("%I64d\n",dp[temp]) ;
            }
        }
    
        return 0 ;
    }
    View Code
    没有梦想,何谈远方
  • 相关阅读:
    css随笔7
    css随笔6
    css随笔5
    *css随笔4
    css3随笔3
    css随笔2
    css随笔1
    HTML总结
    HTML随笔2
    消息转发原理
  • 原文地址:https://www.cnblogs.com/zyue/p/3111769.html
Copyright © 2011-2022 走看看