(非公共题目)

问题描述

  小 w 偶然间⻅到了一个 DAG。这个 DAG 有 m 层,第一层只有一个源点,最后一层只有一个汇点,剩下的每一层都有 k 个节点。

  现在小 w 每次可以取反第 i(1 < i < n − 1) 层和第 i + 1 层之间的连边。也就是把原本从(i, k1 ) 连到 (i+1, k2 ) 的边,变成从 (i , k2 ) 连到 (i+1, k1)。请问他有多少种取反的方案,把从源点到汇点的路径数变成偶数条?

  答案对 998244353 取模。

输入格式

  一行两个整数 m,k。

  接下来 m − 1 行,第一行和最后一行有 k 个整数 0 或 1,剩下每行有 k2 个整数 0 或 1,第(j − 1) × k + t 个整数表示 (i, j) 到 (i + 1, t) 有没有边。

输出格式

  一行一个整数表示答案。

样例输入


样例输出

4

数据规模与约定

20% 的数据满足 n ≤ 10,k ≤ 2。
40% 的数据满足 n ≤ 103,k ≤ 2。
60% 的数据满足 m ≤ 103,k ≤ 5。
100% 的数据满足 4 ≤ m ≤ 104,k ≤ 10。

题解:

  首先发现k ≤ 10,可以状态压缩。我们设dp[i][j]代表到了i行,当前行的状态为j的情况下的方案数。状态中的0和1代表当前行的每一个点,上面到这一个点的路径的条数的奇偶。

  我们预处理一个数组orz[i]代表i这个数的状态,也就是i这个数的二进制位上1的个数的奇偶。这个可以递推不用一个一个求。

  然后dp初值自然就是源点到第2层的状态了(第一层为源点)。把源点向i如果有连边,那么s|=(1<<i)。然后dp[1][s]=1。

  对于中间的层数,我们枚举所有的状态1~210-1。然后进行转移,设a[i]代表当前这两层下面的那一层的第i个点,可以从上面哪一个点来,压缩一下,例如a[2]=5(101)代表上一层的点1和3有连向这一层的点2的一条边。然后我们设一个集合S=0。对于这一层的每一个点i。如果上一层的状态status,与(&)上这一个点的a[i],可以不能转移的自然就变成0了。到上一层的点的路径的奇偶状态转移到了这一个点,如果相加为奇数,也就是orz[status&a[i]]=1,的话代表到这一个点的路径的条数为奇数,那么集合S|=(1<<i)即可,S就是这一层的状态,我们一个一个的填进去。然后dp[i][S]+=dp[i-1][status]。取个模就可以了。然后对于题目中所说的“取反”的边,同样使用一个b[i]来存开一个SS=0来存同样转移即可了。

  最后只要统计有哪些点连向汇点,就可以枚举n-1层所有可能的状态,如果status&s的orz是偶数,那么就可以ans+=dp[n-1][s]。

  数组滚滚Great!

 #include<queue>
#include<cstdio>
#include<vector>
#include<cstring>
#include<iostream>
#include<algorithm>
#define RG register
#define LL long long
#define fre(a) freopen(a".in","r",stdin);freopen(a".out","w",stdout);
using namespace std;
const int MAXN=,mod=;
int n,k,ans,s;
int dp[][(<<)+],orz[(<<)+];
int main()
{
fre("adore");
scanf("%d%d",&n,&k);
int All=(<<k)-;
int *now=dp[],*la=dp[];
for(int i=;i<=All;i++) orz[i]=orz[i>>]^(i&);
for(int i=,x;i<k;i++)
{
scanf("%d",&x);
s|=(x<<i);
}
la[s]=;
for(int i=;i<=n-;i++)
{
int a[]={},b[]={};
memset(now,,sizeof dp[]);
for(int j=,x;j<k;j++)
for(int l=;l<k;l++)
{
scanf("%d",&x);
a[l]|=(x<<j);
b[j]|=(x<<l);
}
for(int j=,S0,S1;j<=All;j++)
{
if(la[j])//加速
{
S0=S1=;
for(int l=;l<k;l++)
{
S0|=(orz[j&a[l]]<<l);
S1|=(orz[j&b[l]]<<l);
}
(now[S0]+=la[j])%=mod;
(now[S1]+=la[j])%=mod;
}
}
swap(now,la);//滚动数组。
}
s=;
for(int i=,x;i<k;i++)
{
scanf("%d",&x);
s|=(x<<i);
}
for(int i=;i<=All;i++)
(ans+=(orz[s&i]?:la[i]))%=mod;
printf("%d\n",ans);
return ;
}

Adore的更多相关文章

  1. Adore 解题报告

    Adore 问题描述 小\(\text{w}\) 偶然间得到了\(1\)个 \(DAG\). 这个 \(DAG\) 有 \(m\) 层,第\(1\)层只有\(1\)个源点,最后\(1\)层只有\(1\ ...

  2. Let Us Adore 让我们来敬拜祂 中文歌词

      Verse 1 诸天宣告 神的荣耀 万国万民 都将赞美 宣扬祂奇妙 The heavens declare The glory of God And all of the world Will j ...

  3. 【CSP模拟赛】Adore(状压dp 二进制)

    题目描述 小w偶然间见到了一个DAG.这个DAG有m层,第一层只有一个源点,最后一层只有一个汇点,剩下的每一层都有k个节点.现在小w每次可以取反第i(1<i<n-1)层和第i+1层之间的连 ...

  4. 【NOIP2017提高A组模拟10.7】Adore

    题目 小w 偶然间见到了一个DAG. 这个DAG 有m 层,第一层只有一个源点,最后一层只有一个汇点,剩下的每一层都有k 个节点. 现在小w 每次可以取反第i(1 < i < n - 1) ...

  5. [JZOJ5398]:Adore(状压DP+记忆化搜索)

    题目描述 小$w$偶然间见到了一个$DAG$. 这个$DAG$有$m$层,第一层只有一个源点,最后一层只有一个汇点,剩下的每一层都有$k$个节点. 现在小$w$每次可以取反第$i(1<i< ...

  6. stella mccartney falabella foldover tote a few eye observed

    Lately, the particular Heyuan City Courtroom retrial, in order to commit the criminal offense of cou ...

  7. HYSBZ 2145 悄悄话

    2145: 悄悄话 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 271  Solved: 104[Submit][Status][Discuss] ...

  8. Chkrootkit Sourcecode Learning

    目录 . Chkrootkit Introduce . Source Code Frame . chklastlog.c . chkwtmp.c . ifpromisc.c . chkproc.c . ...

  9. Rootkit Hunter Sourcecode Learning

    目录 . Rootkit Hunter Introduce() . Source Code Frame() . do_system_check_initialisation() . do_system ...

随机推荐

  1. poj(1011)——Sticks(经典的dfs+剪枝)

    题目的大致意思是: 如今有n根木棍,然后须要把它们拼成相同长度的木棍,问满足这个条件的最短的长度是多少? 想法嘛:那肯定是dfs把长度搜一遍就好,但问题的关键是这里会超时.那么就要用到剪枝的原理了. ...

  2. svn 创建分支、切换分支 及 合并分支 操作

    关联远程仓库: 右键  ---  点击 ' SVN Checkout...' 生成 打开trunk目录,在trunk目录下新建两个文本文件A.java,B.java: 打开A.java输入以下内容: ...

  3. Adobe Flash builder破解方法

    Flash Builder 4 有许多新的特性,可以结合新的功能使用新的Flex 4框架创建出更炫的应用.基于用户的反馈,对以数据中心的开发也进行了优化:对类如配置从服务器返回的数据类型这样的任务,也 ...

  4. 李洪强iOS开发之 - 指定刷新tableview的某一组

    李洪强iOS开发之 - 指定刷新tableview的某一组

  5. Bean定义并注册到spring

    1.XML配置文件 2.Annotation注解 3.Java Code 配置方式 BeanDefinitionRegistryPostProcessor

  6. YTU 2453: 我想有套北京的房

    2453: 我想有套北京的房 时间限制: 1 Sec  内存限制: 128 MB 提交: 796  解决: 289 题目描述 小原是一个软件工程师,名叫原黛玛,他在北京工作.现在有一套房子,价格200 ...

  7. Java数据库操作类演示

    只在mysql上测试过,不知道算不算好使​1. [代码][Java]代码     package org.load.demo; import java.io.IOException;import ja ...

  8. docker 初试---常用命令

    http://blog.csdn.net/wsscy2004/article/details/25878363 常用命令 查看容器的root用户密码 docker logs <容器名orID&g ...

  9. UVA-11054(扫描法)

    题意: n个等距村庄,每个村庄要么买酒要么卖酒,把k个单位的酒运到相邻村庄去需要k个单位的劳动力,问最少需要多少劳动力才能满足所有的村庄的要求; 思路: 上次做了一个环的,这个是直线的,就是一个大水题 ...

  10. 机器学习 Hidden Markov Models 3

    Viterbi Algorithm 前面我们提到过,HMM的第二类问题是利用HMM模型和可观察序列寻找最有可能生成该观察序列的隐藏变量的序列.简单来说,第一类问题是通过模型计算生成观察序列的概率,而第 ...