Adore 解题报告
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 解题报告的更多相关文章
- CH Round #56 - 国庆节欢乐赛解题报告
最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...
- 二模13day1解题报告
二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...
- BZOJ 1051 最受欢迎的牛 解题报告
题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4438 Solved: 2353[S ...
- 习题:codevs 2822 爱在心中 解题报告
这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...
- 习题:codevs 1035 火车停留解题报告
本蒟蒻又来写解题报告了.这次的题目是codevs 1035 火车停留. 题目大意就是给m个火车的到达时间.停留时间和车载货物的价值,车站有n个车道,而火车停留一次车站就会从车载货物价值中获得1%的利润 ...
- 习题: codevs 2492 上帝造题的七分钟2 解题报告
这道题是受到大犇MagHSK的启发我才得以想出来的,蒟蒻觉得自己的代码跟MagHSK大犇的代码完全比不上,所以这里蒟蒻就套用了MagHSK大犇的代码(大家可以关注下我的博客,友情链接就是大犇MagHS ...
- 习题:codevs 1519 过路费 解题报告
今天拿了这道题目练练手,感觉自己代码能力又增强了不少: 我的思路跟别人可能不一样. 首先我们很容易就能看出,我们需要的边就是最小生成树算法kruskal算法求出来的边,其余的边都可以删掉,于是就有了这 ...
- NOIP2016提高组解题报告
NOIP2016提高组解题报告 更正:NOIP day1 T2天天爱跑步 解题思路见代码. NOIP2016代码整合
- LeetCode 解题报告索引
最近在准备找工作的算法题,刷刷LeetCode,以下是我的解题报告索引,每一题几乎都有详细的说明,供各位码农参考.根据我自己做的进度持续更新中...... ...
随机推荐
- 使用NPOI快速导出导入Excel
这两天做项目需要导入导出EXCEL,是基于NPOI的封装,设计思路是使用DataTable,然后导出一个和DataTable一模一样的Excel表出来 github地址:https://github. ...
- video.js使用技巧
https://www.awaimai.com/2053.html https://www.jianshu.com/p/16fa00a1ca8e
- 通过SVI实现VLAN间通信
两个不同网段的计算机与三层交换机直连,通过SVI实现VLAN间通信vlan 1 //几个不同网段就创建几个VLANvlan 2 int f0/1 //划分VLANswitchport mode acc ...
- error:control reaches end of non-void function [-Werror=return-type]
在做LeetCode上的题目时,出现了这个错误, 原代码如下: class Solution { public: vector<int> twoSum(vector<int>& ...
- dijkstra算法学习
dijkstra算法学习 一.最短路径 单源最短路径:计算源点到其他各顶点的最短路径的长度 全局最短路径:图中任意两点的最短路径 Dijkstra.Bellman-Ford.SPFA求单源最短路径 F ...
- FireDAC 连接Access (accdb)数据库
FireDAC可以方便连接数据库,但是要连接新版本的accdb数据库,要注意这样的事项(以Office2010版为例) 安装Office2010 x86版,注意,不能安装x64版,因为Delphi I ...
- 一步一步学Linq to sql(六):探究特性
延迟执行 IQueryable query = from c in ctx.Customers select c; 这样的查询句法不会导致语句立即执行,它仅仅是一个描述,对应一个SQL.仅仅在需要使用 ...
- Mac OS下搭建Hadoop + Spark集群
首先注意版本兼容问题!!!本文采用的是Scala 2.11.8 + Hadoop 2.7.5 + Spark 2.2.0 请在下载Spark时务必看清对应的Scala和Hadoop版本! 一.配置JD ...
- mock.js中新增测试接口无效,返回404
项目是使用的npm+vue+mock模拟数据 我碰到的是在mock配置文件中新增接口,但是接口在测试时无效,返回404.但是在前端代码中把新接口换成配置文件中之前就有的,然后测试就正常了. 所以按问题 ...
- 记一次艰难的CTP调试
一个atmel,mxt540e的CTP触摸屏. 中断配置为下降沿,输入上拉. 总是只能触发一次中断,中断脚就一直低电平,无法拉高.这只是表面现象 不停找底层I2C驱动,改代码,没用.要靠波形来说话 ...