Adore

问题描述

小\(\text{w}\) 偶然间得到了\(1\)个 \(DAG\)。

这个 \(DAG\) 有 \(m\) 层,第\(1\)层只有\(1\)个源点,最后\(1\)层只有\(1\)个汇点,剩下的每\(1\)层都有 \(k\) 个

节点。

现在小\(\text{w}\) 每次可以取反第 \(i(1 < i < m - 1)\) 层和第 \(i + 1\) 层之间的连边。也就是把原本从

\((i, k_1)\) 连到 \((i + 1, k_2)\) 的边,变成从 \((i, k_2)\) 连到 \((i + 1, k_1)\)。

请问他有多少种取反的方案,把从源点到汇点的路径数变成偶数条?

答案对 \(998244353\) 取模。

输入格式

第一行两个整数 \(m\),\(k\)。

接下来 \(m - 1\) 行, 第一行和最后一行有 \(k\) 个整数 \(0\) 或 \(1\),剩下每行有 \(k^2\) 个整数 \(0\) 或 \(1\),第

\((j - 1) \times k + t\) 个整数表示 \((i, j)\) 到 \((i + 1, t)\) 有没有边。

输出格式

一行一个整数表示答案。

数据规模与约定

\(20\%\) 的数据满足\(m \le 10,k \le 2\)。

\(40\%\) 的数据满足\(m \le 10^3,k \le 2\)。

\(60\%\) 的数据满足\(m \le10^3,k \le 5\)。

\(100\%\) 的数据满足\(4 \le m \le 10^4,k \le 10\)。

Solution

如果你读懂了题目,那么应该不是那么难想。

如何保证偶数条?发现奇偶可以成为状态,于是状压。

令\(dp_{i,s}\)表示第\(i\)层节点状态为\(s\)的方案数

转移也不难,但是我比较傻写了一种\(O(mk^22^k)\)的辣鸡做法,成功只拿了\(60pts\)

如果二进制连边就可以做到\(O(mk2^k)\)了,有点轻微卡常还是注意一下。


Code:

#include <cstdio>
const int N=1e4+10;
const int mod=998244353;
int g[N][11][11],m,k,dp[N][1<<10],sta,ans;
int main()
{
scanf("%d%d",&m,&k);
for(int is,j=1;j<=k;j++)
{
scanf("%d",&is);
sta|=is<<j-1;
}
dp[2][sta]=1;
for(int i=2;i<m-1;i++)
{
int a[12]={0},b[12]={0};
for(int is,j=1;j<=k;j++)
for(int l=1;l<=k;l++)
{
scanf("%d",&is);
a[j]|=is<<l-1;
b[l]|=is<<j-1;
}
for(int s=0;s<1<<k;++s)
if(dp[i][s])
{
int t0=0,t1=0;
for(int l=1;l<=k;l++)
if(s>>l-1&1)
t0^=a[l],t1^=b[l];
(dp[i+1][t0]+=dp[i][s])%=mod;
(dp[i+1][t1]+=dp[i][s])%=mod;
}
}
sta=0;
for(int is,j=1;j<=k;j++)
{
scanf("%d",&is);
sta|=is<<j-1;
}
for(int s=0;s<1<<k;s++)
{
if(dp[m-1][s])
{
int t=0;
for(int i=1;i<=k;i++)
if(s>>i-1&1&&sta>>i-1&1)
t^=1;
if(!t) (ans+=dp[m-1][s])%=mod;
}
}
printf("%d\n",ans);
return 0;
}

2018.10.20

Adore 解题报告的更多相关文章

  1. CH Round #56 - 国庆节欢乐赛解题报告

    最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...

  2. 二模13day1解题报告

    二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...

  3. BZOJ 1051 最受欢迎的牛 解题报告

    题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4438  Solved: 2353[S ...

  4. 习题:codevs 2822 爱在心中 解题报告

    这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...

  5. 习题:codevs 1035 火车停留解题报告

    本蒟蒻又来写解题报告了.这次的题目是codevs 1035 火车停留. 题目大意就是给m个火车的到达时间.停留时间和车载货物的价值,车站有n个车道,而火车停留一次车站就会从车载货物价值中获得1%的利润 ...

  6. 习题: codevs 2492 上帝造题的七分钟2 解题报告

    这道题是受到大犇MagHSK的启发我才得以想出来的,蒟蒻觉得自己的代码跟MagHSK大犇的代码完全比不上,所以这里蒟蒻就套用了MagHSK大犇的代码(大家可以关注下我的博客,友情链接就是大犇MagHS ...

  7. 习题:codevs 1519 过路费 解题报告

    今天拿了这道题目练练手,感觉自己代码能力又增强了不少: 我的思路跟别人可能不一样. 首先我们很容易就能看出,我们需要的边就是最小生成树算法kruskal算法求出来的边,其余的边都可以删掉,于是就有了这 ...

  8. NOIP2016提高组解题报告

    NOIP2016提高组解题报告 更正:NOIP day1 T2天天爱跑步 解题思路见代码. NOIP2016代码整合

  9. LeetCode 解题报告索引

    最近在准备找工作的算法题,刷刷LeetCode,以下是我的解题报告索引,每一题几乎都有详细的说明,供各位码农参考.根据我自己做的进度持续更新中......                        ...

随机推荐

  1. C++ 指针初始化要注意的地方

    1. 声明多个指针的时候: int* P1,P2; 如上所示,声明的是创建一个指针P1和一个int型的变量P2.而不是声明的两个指针. 对每个指针变量名,都需要使用一个*. 在C++中,int* 是一 ...

  2. [转载]三小时学会Kubernetes:容器编排详细指南

    原翻译by梁晓勇 原英文:Learn Kubernetes in Under 3 Hours: A Detailed Guide to Orchestrating Containers 我很奇怪,为什 ...

  3. Codeforces Round #500 (Div. 2) BC

    CodeForces 1013B And CodeForces 1013C  Photo of The Sky B 可以发现只有一次与操作是有意义的,所以答案只有-1,0,1,2四种情况 #inclu ...

  4. 剑指offer题目系列二

    本篇延续上一篇,介绍<剑指offer>第二版中的四个题目:从尾到头打印链表.用两个栈实现队列.旋转数组的最小数字.二进制中1的个数. 5.从尾到头打印链表 题目:输入一个链表的头结点,从尾 ...

  5. python2.7练习小例子(六)

        6):题目:斐波那契数列.     程序分析:斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0.1.1.2.3.5.8.13.21.34.……. ...

  6. Spring + MySQL + Mybatis + Redis【二级缓存】

    一.Redis环境 Redis 官网 :http://redis.io/ windows下载:https://github.com/dmajkic/redis/downloads 1.文件解压缩 2. ...

  7. hdu畅通工程(并查集)

    Problem Description 某省调查城镇交通状况,得到现有城镇道路统计表,表中列出了每条道路直接连通的城镇.省政府“畅通工程”的目标是使全省任何两个城镇间都可以实现交通(但不一定有直接的道 ...

  8. No parser was explicitly specified, so I'm using the best available HTML parser for this system ("html.parser").警告解决方法

    在使用BeautifulSoup库时出现该警告,虽然不影响正常运行,但强迫症不能忍啊!! 详细警告信息如下: UserWarning: No parser was explicitly specifi ...

  9. [转]URL传中文参数导致乱码的解决方案之encodeURI

    通过URL传中文参数时,在服务端后台获取到的值往往会出现乱码.解决方案有很多种.本文介绍如何通过encodeURI来解决中文乱码问题. 首先,在前端页面准备参数的时候,需要对中文参数进行encode处 ...

  10. 2018春季校园招聘笔经面经合集:Java开发岗

    2018春季校园招聘笔经面经合集:Java开发岗 以下为精选面经: 美团外卖配送部后台开发面经 nowcoder.com/discuss/76 春招总结,干货满满 nowcoder.com/discu ...