19-11-10-Night
关于$Miemeng$,它死了。
大家有没有记得我在暑假里曾经写过一个著名模数?
const int Mod=998224353;现在有续集了(捂脸)(改不过题.jpg)
const int Mod=988244353;
ZJ:
我对不起大家我又咕咕咕了,话说为什么我挂起的电脑……
T1Adore,看起来很熟悉……不知道是什么时候见过这个词……
于是发现不可做。打一个暴力就丢了。
T2发现暴力很好打,先码了一个,先rand了几个数据,发现答案大都是$1\ 2$
emm,本来想一边输入一边扫,但是后来弃掉了(为什么要弃啊啊啊?
T3发现很贪心,但是只会输出$n$(滑稽
(后来听说输出$\frac{n}{s}$有$50$)
|
39
|
Miemeng | 0
00:00:03
|
50
00:00:04
|
20
00:00:05
|
70
00:00:05
|
啊T1为什么爆〇了????
TJ:
T1
状压即可,设$f_{i,s}$为第$i$层点权奇偶性为$s$(奇为$1$,偶为$0$)时前$i$层的方案数
于是预处理取反边,并且直接转移就好了。
最后的答案就是$f_{n,0}$
复杂度$\Theta(NK 2^K)$
#include <iostream>
#include <cstring>
#include <cstdio> //#include "debug.h" #define N 11111
#define K 12
#define S (1<<K)+111
#define LL long long
using namespace std; const int Mod=998244353;
int cn,pn;
LL dp[N][S];
int mp[N][K],pm[N][K];
int dat[N][K][K]; void prerun(){
for(int i=1;i<=pn;i++){
mp[1][1] |= dat[1][1][i]<<(i-1);
}
for(int i=2;i<cn-1;i++){
for(int j=1;j<=pn;j++){
for(int k=1;k<=pn;k++){
mp[i][j] |= dat[i][j][k]<<(k-1);
pm[i][k] |= dat[i][j][k]<<(j-1);
}
}
}
for(int i=1;i<=pn;i++){
mp[cn-1][i] |= dat[cn-1][i][1];
// cout<<mp[cn-1][i]<<" ";
}
// cout<<endl;
}
int main(){
#ifndef LOCAL
freopen("adore.in" ,"r",stdin);
freopen("adore.out","w",stdout);
#endif
scanf("%d%d",&cn,&pn);
for(int i=1;i<=pn;i++){
scanf("%d",&dat[1][1][i]);
}
for(int i=2;i<cn-1;i++){
for(int j=1;j<=pn;j++){
for(int k=1;k<=pn;k++){
scanf("%d",&dat[i][j][k]);
}
}
}
for(int i=1;i<=pn;i++){
scanf("%d",&dat[cn-1][i][1]);
}
prerun();
/* for(int i=1;i<=cn;i++){
for(int j=1;j<=pn;j++){
cout<<i<<" "<<j<<" "<<bin(mp[i][j],pn)<<endl;
}
}*/
dp[2][mp[1][1]]=1;
for(int i=2;i<cn-1;i++){
for(int s=0;s<1<<pn;s++){
// cout<<"dp["<<i<<"]["<<bin(s,pn)<<"]="<<dp[i][s]<<endl;
int pos=0,sop=0;
for(int j=1;j<=pn;j++){
int k=1<<(j-1);
if(k&s){
pos^=mp[i][j];
sop^=pm[i][j];
}
}
dp[i+1][pos]+=dp[i][s];
dp[i+1][pos]%=Mod;
dp[i+1][sop]+=dp[i][s];
dp[i+1][sop]%=Mod;
}
}
for(int s=0;s<1<<pn;s++){
int pos=0;
// cout<<"dp["<<cn-1<<"]["<<bin(s,pn)<<"]="<<dp[cn-1][s]<<endl;
for(int i=1;i<=pn;i++){
int j=1<<(i-1);
if(j&s){
pos^=mp[cn-1][i];
// cout<<"pos:"<<bin(pos,pn)<<"<-"<<j<<" "<<mp[cn-1][j]<<endl;
}
}
dp[cn][pos]+=dp[cn-1][s];
dp[cn][pos]%=Mod;
}
printf("%lld\n",dp[cn][0]);
}
T2:
考试的小剪枝暴力tong过本题。
#include <iostream>
#include <cstring>
#include <cstdio>
#include <bitset>
#define N 6666
using namespace std; int sn;
char str[N*100];
bitset <2*N> vals[N];
int main(){
#ifndef LOCAL
freopen("confess.in" ,"r",stdin);
freopen("confess.out","w",stdout);
#endif
scanf("%d",&sn);
for(int i=1;i<=sn+1;i++){
int cnt=0;
scanf("%s",str);
int len=strlen(str);
for(int j=0;j<len;j++){
int dat=str[j]-33;
for(int k=0;k<6;k++){
vals[i]<<=1;
cnt++;
vals[i].set(0,dat>>k&1);
if(cnt==2*sn)goto nxtt;
}
}
nxtt:;
for(int j=1;j<i;j++){
if((int)(vals[i]&vals[j]).count()>=sn/2){
cout<<i<<" "<<j<<endl;
return 0;
}
}
}
}
但是正解是随机化……
(随机化可过的题大多都可以暴力剪枝过……)
T3咕掉了,也不想粘题解。
19-11-10-Night的更多相关文章
- Update 19.11 for Azure Sphere
今天,微软发布了面向Azure Sphere的19.11更新,其主要亮点就是加入了对开发工具Visual Studio Code和Linux开发环境的支持.具体来讲,本次更新包含3个部分: 1. Az ...
- 2016/11/10 吃吃喝喝Hacking Thursday Night聚餐活动 at Dunkin Donuts
店名:Dunkin Donuts 唐恩都乐 点评:http://www.dianping.com/shop/21378231 地址:静安区南京西路1649号静安公园内(近静安公园) 走法:地铁2号线静 ...
- 微信iphone7、 ios10播放视频解决方案 2016.11.10
2016.11.10日更新以下方法 微信最新出同层播放规范 即使是官方的也无法解决所有android手机的问题. 另外iphone 5 .5s 某些手机始终会弹出播放,请继续采用 “以下是老的解决办法 ...
- ubuntu 11.10 安装apache2 tomcat6
ubuntu 11.10 安装apache2 tomcat6 导读 Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目 ...
- 【转】ubuntu 11.10(32位系统)下编译android源码
原文网址:http://www.cnblogs.com/dwayne/archive/2011/11/16/2251734.html 本文介绍在ubuntu 11.10系统下编译android 2.3 ...
- Ubuntu 11.10 安装GMONE3,卸载 UNITY和UNITY 2D
Ubuntu 11.10安装GNOME3: 1)sudo apt-get install gnome-shell sudo apt-get install gnome-themes* (或者 ...
- 在Ubuntu 11.10工具栏上用数字显示网速、CPU负荷和内存占用量『译』
基本上照抄了<How To Display Network Upload / Download Speed On The Panel In Ubuntu 11.04>,只不过我的实践环境是 ...
- Ubuntu 11.10 Server下搭建Maven私服
安装Nexus服务的文档可以参考官方站点:http://www.sonatype.com/books/nexus-book/reference/install-sect-install.html ...
- Ubuntu 11.10下GRUB 2 1.99版编译安装笔记
Ubuntu 11.10下GRUB 2 1.99版编译安装笔记 以下的安装笔记,都是QLi自己学习grub2 时,所整理的,还是新手,有错误的话,请大家帮忙就别提出来了. 最新版grub V1.99官 ...
- 显示 Ubuntu 11.10 的 终端窗口
显示 Ubuntu 11.10 的 终端窗口 一.点击左上角的图标 -> 在search框里搜索termial . 二.快捷键:Ctrl+Alt+t.
随机推荐
- spring boot 结合jsp简单示例
引入依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>sp ...
- arm-linux-objdump 的使用
1. 查看静态库或.o 文件的组成文件 [arm@localhost gcc]$ armlinuxobjdump a libhello.a 2. 查看静态库或.o 文件的络组成部分的头部分 [a ...
- 神经网络 (1)- Alexnet
文章目录 模型结构 conv1层 conv2层 conv3层 conv4层 conv5层 FC6全链接图: fc7全连接层:和fc6类似. fc8链接层: 模型优化 选择ReLU作为激活函数 多GPU ...
- Dos中转义符
遇到个问题: java test R=<file> 11 22 按理说应该打印 R=<file> 11 22 但是,系统报错,写的是系统找不到指定文件. 是"< ...
- css---8 过渡属性刨析
1. transition-property 默认值为 all,表示所有可被动画的属性都表现出过渡动 可以指定多个 property 属性值: none 没有过渡动画. all 所有可被动 ...
- Vim: 强大的g
来源于:http://vim.wikia.com/wiki/Power_of_g 一般格式: :[range]g/pattern/cmd 对range内所有符合pattern的行执行cmd 常见的一些 ...
- day30 python类的继承,抽象类等
Python之路,Day17 = Python基础17-面向对象入门 继承 class Student(People): pass print(Student.__bases__) # 查看 Stud ...
- thinkphp 页面Trace信息
调试模式并不能完全满足我们调试的需要,有时候我们需要手动的输出一些调试信息.除了本身可以借助一些开发工具进行调试外,ThinkPHP还提供了一些内置的调试工具和函数.例如,页面Trace功能就是Thi ...
- python用类实现装饰器
一.代码 #利用__call__方法,装饰器的执行流程:当添加装饰器语法糖时,会把语法糖的变量名加()执行,并将被装饰的函数名传入.所以当类加()执行时,执行了__init__,产生的对象就是被装饰的 ...
- js 中继承方式小谈
题外话 前段时间面试中笔试题有这道题目: 请实现一个继承链,要求如下: 构造函数A():构造函数中有consoleA方法,可以实现console.log("a") 实例对象 a:a ...