85 条题解

  • 0
    @ 2006-08-21 16:21:30

    是呀~

    O(n^2)我的也过不了 就第7个数据超了~~

  • 0
    @ 2006-08-21 11:42:11

    用b[i]表示前i个人中男生的数目

    用g[i]表示前i个人中女生的数目

    d[i]=g[i]-b[i] 表示前i个人中男女生相差的数目

    若d[i]=d[j]说明从第i+1个人开始到第j个人男女生增长的数目是一样的,

    也就是其中男女生数目一样的

    找到j-i最大的一组就可以了

    0 1 0 0 0 1 1 0 0

    b 0 1 1 1 1 2 3 3 3

    g 1 1 2 3 4 4 4 5 6

    g-b 1 0 1 2 3 2 1 2 3

  • 0
    @ 2006-08-20 14:50:05

    先让0变为-1

    再用hash

  • 0
    @ 2006-08-25 15:16:53

    编译通过...

    ├ 测试数据 01:答案正确... 0ms

    ├ 测试数据 02:答案正确... 0ms

    ├ 测试数据 03:答案正确... 0ms

    ├ 测试数据 04:答案正确... 0ms

    ├ 测试数据 05:答案正确... 0ms

    ├ 测试数据 06:答案正确... 0ms

    ├ 测试数据 07:答案正确... 806ms

    ├ 测试数据 08:答案正确... 0ms

    ├ 测试数据 09:答案正确... 0ms

    ├ 测试数据 10:答案正确... 0ms

    ---|---|---|---|---|---|---|---|-

    Accepted 有效得分:100 有效耗时:806ms

    第7组是什么??差点又过不了!

  • -1
    @ 2017-05-08 12:39:42
    /*
    好题~Orz
    不过感觉和动态规划没有什么关系
    如果是单独处理1 0
    肯定会很难处理
    所以我们可以将读入的0全部转换为-1
    则男女生人数相同的条件就是子序列和为0咯
    即如果s[i]==s[j]
    那么这就是一个满足条件的子序列 长度为j-i
    这样一想就会很简单了
    但是如果我们枚举所有的子序列
    那么复杂度达到了O(n^2)
    肯定是会超时的
    那么我们怎么优化这个算法呢
    我们来看    我们用f数组来记录某个序列和的位置
    f[i]表示满足s[k]==i的k的最前的一个位置
    因为我们知道
    如果在后面找到了一个j 
    要在前面找一个位置i满足s[i]==s[j]
    构成一个满足条件的子序列
    那么我们肯定是选择最前面的最好
    这个很容易证明吧
    所以我们只用记录每个数值最前面的那个数位置就好了
    然后f数组初始化为-1
    用来判断是否出现过这个数值
    如果第一次出现 就记录下这个数组
    如果不是第一次出现   就尝试这个长度能否更新答案
    这样扫描一遍就好了
    复杂度为O(n)
    感觉有点像NOIP选择客栈那道题QAQ
    弱逼的我还是这么弱逼
    */
    #include <iostream>
    #include <cstdio>
    #include <algorithm>
    #include <cstring>
    using namespace std;
    
    const int MAXN=100009;
    int n;
    int s[MAXN];
    int f[MAXN*2];
    int ans;
    
    void init()
    {
        cin>>n;
        int x;
        for(int i=1;i<=n;i++)
        {
            cin>>x;
            if(!x)  
                s[i]=s[i-1]-1;
            else
                s[i]=s[i-1]+1;
        }
    }
    
    int main()
    {
        init();
        memset(f,-1,sizeof(f));
        for(int i=0;i<=n;i++)
        {
            if(f[s[i]+n]!=-1)
                ans=max(ans,i-f[s[i]+n]);
            else
                f[s[i]+n]=i;
        }
        cout<<ans<<endl;
        return 0;
    }
    
    

信息

ID
1195
难度
5
分类
动态规划 点击显示
标签
(无)
递交数
1552
已通过
553
通过率
36%
被复制
6
上传者