zoukankan      html  css  js  c++  java
  • 【刷题】序列问题

    题面在此

     然后

    方案1:

    裸上,N^3

    #include<cstdio>
    #include<cstdlib>
    using namespace std;
    int n;
    const int N=103,M=1024;
    int d[N];
    
    int back[N][M];
    void get_back(int nw,int pre,int x)
    {
        for(int i=0;i<1024;i++)
            if(back[pre][i])
                back[nw][i]+=back[pre][i],back[nw][i&x]+=back[pre][i];
        back[nw][x]++;
    }
    
    int front[N][M];
    void get_front(int nw,int pre,int x)
    {
        for(int i=0;i<1024;i++)
        {
            for(int j=pre;j;j--)    
                front[nw][i^x]+=front[j][i];    
        }
        front[nw][x]++;
    }
    
    long long ans;
    int main()
    {
        scanf("%d",&n);
        for(int i=1;i<=n;i++)
            scanf("%d",&d[i]);
        
        for(int i=n-1;i;i--)
            get_back(i,i+1,d[i+1]);
        for(int i=1;i<n;i++)
            get_front(i,i-1,d[i]);
        
        for(int i=1;i<n;i++)
        {
            for(int j=0;j<1024;j++)
                if(front[i][j]) ans+=back[i][j]*front[i][j];
        }
        printf("%lld
    ",ans);
        
        return 0;
    }

    方案二:

    DP,解法真的很有意思

    一个重要的发现:
    两个数相等就是,两个数异或等于0

    所以就可以把问题化简
    求一个长度为n的序列中,选择至少两个数,
    将数设为a1,a2,a3...ai...aj
    使a1^a2^a3^...^ai & ai+1 & ... aj
    结果为0

    这里减少的是一个枚举i,
    和一个分别枚举1024*n的复杂度

    #include<cstdio>
    #include<cstdlib>
    using namespace std;
    int n;
    const int N=1003;
    int d[N];
    long long f[N][1024][2];//这个0,1表示这一次进行的运算 & ^ 
    
    int main()
    {
        scanf("%d",&n);
        for(int i=1;i<=n;i++) scanf("%d",&d[i]);
        
        f[n][d[n]][0]=1; 
        for(int i=n-1;i;i--)
        {    
            for(int j=0;j<1024;j++)
            {
                f[i][j][0]+=f[i+1][j][0];
                f[i][j][1]+=f[i+1][j][1];
                
                f[i][j^d[i] ][1] +=f[i+1][j][1]+f[i+1][j][0]; 
                f[i][j&d[i] ][0] +=f[i+1][j][0];
            }
            f[i][d[i]][0]++; 
        }
        
        printf("%lld
    ",f[1][0][1]);
        return 0;
    }

    估算一下答案的范围,特别大,

    (虽然我其实不会估算)

    反正肯定加爆了,需要压位高精度

    代码等会上

  • 相关阅读:
    转 linux shell自定义函数(定义、返回值、变量作用域)介绍
    转 Shell调试篇
    WIN2012的桌面和开始菜单跑到什么地方去了
    转 awr自动收集脚本
    Troubleshooting Guide for ORA-12541 TNS: No Listener
    test
    向Linus学习,让代码具有good taste
    php 页面展示
    c++ list sort
    c++ word类型
  • 原文地址:https://www.cnblogs.com/xwww666666/p/11432027.html
Copyright © 2011-2022 走看看