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,以下是我的解题报告索引,每一题几乎都有详细的说明,供各位码农参考.根据我自己做的进度持续更新中...... ...
随机推荐
- 介绍几个PHP 自带的加密解密函数
PHP 自带的加密解密函数 目前经常使用的加密函数有:md5(), sha1(), crypt(), base64_encode(), urlencode() . 其中 md5(), sha1(), ...
- Linux基础(02)、MTPutty安装和使用
准备工具 1. MTPutty的安装包 2. Putty.exe程序 作用:远程连接操作Centos 安装MTPutty 1.根据提示,一直下一步至下图:选择putty.exe文件的位置即可. 2.选 ...
- jmeter测试报告优化
1.下载jmeter.results.shanhe.me.xsl 将该文件拷贝到jmeter\extras目录下 2.修改jmeter.results.shanhe.me.xsl 这里直接拷贝 jme ...
- ruby 类库组成
一. 核心类库: 二.标准类库: 文本 base64.rb 处理Base64编码的模块 csv.rb CSV(Comma Separated Values)库 ruby 1.8 特性 ...
- labview在编写程序框图中遇到的一些布尔按钮控制布尔指示灯问题
上图布尔控件按下,数据0x04成功发送给下位机,布尔灯不亮. ............... ............. ........... 下图布尔控件按下, ...
- 141. 环形链表 LeetCode报错:runtime error: member access within null pointer of type 'struct ListNode'
/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode ...
- 三种urllib实现网页下载,含cookie模拟登陆
coding=UTF-8 import re import urllib.request, http.cookiejar, urllib.parse # # print('-------------- ...
- 听雷哥浅谈Redis
Linux下安装redis 1.下载源码,解压缩后编译源码. $ wget http://download.redis.io/releases/redis-2.8.3.tar.gz $ tar xzf ...
- hadoop中的方法的作用
/* * InputFormat类: * * 作用: * 1.设置输入的形式; * 2.将输入的数据按照相应的形式分割成一个个spilts后再进一步拆分成<key,value> ...
- APK反编译后添加日志
一.反编译 参考前一篇文章 二.添加寄存器(locals) 因为要添加日志,我们一般需要用一个变量来存储TAG,所以需要增加一个寄存器 如: # virtual methods .method pub ...