Noip模拟20 2021.7.19
T1 玩具
题目读错意思直接报零。。。
拼接方式没读懂以为是个数学题,用卡特兰数,可是的确想多了
数据范围表达出你怎么暴力都行,选择$n^3,dp$
相当于一片森林,每次多加一条边就合并成一棵树
在$dp$过程中统计合并的树的信息再算上贡献就行
T2 y
因为上次考试做过的v是一个将状态提取到数组里
这次为了暴力用了同样的方法
将状态枚举,提取出来后进行$XIN$队
1 #include<bits/stdc++.h>//状压思想枚举每一种状态,然后爆搜
2 #define int long long
3 using namespace std;
4 int n,m,d;bool flag;short pre[21];
5 struct SNOW{int from,to,val,next;};SNOW e[1000000]; int head[1000000],rp;
6 inline void add(int x,int y,int z){e[++rp]=(SNOW){x,y,z,head[x]};head[x]=rp;}
7 inline void dfs(int x,int cnt){
8 if(!cnt){flag=1;return;}
9 for(int i=head[x];i;i=e[i].next)
10 if(e[i].val==pre[cnt]) dfs(e[i].to,cnt-1);
11 return;
12 }
13 namespace WSN{
14 inline int main(){
15 scanf("%lld%lld%lld",&n,&m,&d); int tmp=0;
16 for(int i=1,u,v,c;i<=m;i++){
17 scanf("%lld%lld%lld",&u,&v,&c),add(u,v,c),add(v,u,c);
18 if(!c) tmp++;
19 }
20 if(tmp==m){
21 if(m==1) {cout<<0<<endl;return 0;}
22 else {cout<<1<<endl;return 0;}
23 }
24 int mzs=1<<d,ans=0;
25 for(int i=0;i<mzs;i++){
26 int st=i; flag=0;
27 for(int j=1;j<=d;j++) pre[j]=(st&1),st>>=1;
28 dfs(1,d); if(flag) ans++;
29 }
30 printf("%lld\n",ans);
31 return 0;
32 }
33 }
34 signed main(){return WSN::main();}
正解是一个叫$Meet In the Middle$的东西,其实可以很简单的理解为起点终点向中间去碰数。。
就分别统计以1到它长度为$len/2$的所有状态,距离1为$d$的点到中间$d/2$的所有状态
再依次拼接,查看有没有重复计算的总状态即可
复杂度最高的在于枚举状态,他分成$d/2$的两次枚举,比直接枚举$d$快了不知道多少。。
1 #include<bits/stdc++.h>//状压思想枚举每一种状态,然后爆搜
2 #define int long long
3 using namespace std;
4 int n,m,d,len;
5 bool vis[1<<21];
6 vector<int> vc1[91],vc2[91];
7 bool f1[91][91][1025],f2[91][91][1025];
8 struct SNOW{int from,to,val,next;};SNOW e[1000000]; int head[1000000],rp;
9 inline void add(int x,int y,int z){e[++rp]=(SNOW){x,y,z,head[x]};head[x]=rp;}
10 namespace WSN{
11 inline int main(){
12 scanf("%lld%lld%lld",&n,&m,&d); int ans=0;
13 for(int i=1,u,v,c;i<=m;i++)scanf("%lld%lld%lld",&u,&v,&c),add(u,v,c),add(v,u,c);
14 len=d>>1; f1[0][1][0]=1;
15 for(int i=1;i<=len;i++) for(int j=1;j<=n;j++) for(int k=0;k<(1<<i);k++)
16 for(int u=head[j];u;u=e[u].next) f1[i][e[u].to][k<<1|e[u].val]|=f1[i-1][j][k];
17 int lenn;
18 if(d%2!=0) lenn=len+1;
19 else lenn=len;
20 for(int i=1;i<=n;i++) f2[0][i][0]=1;
21 for(int i=1;i<=lenn;i++) for(int j=1;j<=n;j++) for(int k=0;k<(1<<i);k++)
22 for(int u=head[j];u;u=e[u].next) f2[i][e[u].to][k<<1|e[u].val]|=f2[i-1][j][k];
23 for(int i=1;i<=n;i++){
24 for(int k=0;k<(1<<len);k++) if(f1[len][i][k]) vc1[i].push_back(k);
25 for(int k=0;k<(1<<lenn);k++) if(f2[lenn][i][k]) vc2[i].push_back(k);
26 }
27 for(int i=1;i<=n;i++) for(int j=0;j<vc1[i].size();j++) for(int k=0;k<vc2[i].size();k++)
28 if(!vis[(vc1[i][j]<<lenn|vc2[i][k])]) ans++,vis[(vc1[i][j]<<lenn|vc2[i][k])]++;
29 printf("%lld\n",ans);
30 return 0;
31 }
32 }
33 signed main(){return WSN::main();}
优秀的缩进
T3 z
超级麻烦的一道题,现在还没改出来,先沽了~~~
Noip模拟20 2021.7.19的更多相关文章
- Noip模拟44 2021.8.19
比较惊人的排行榜 更不用说爆零的人数了,为什么联赛会这么难!!害怕了 还要再努力鸭 T1 Emotional Flutter 考场上没切掉的神仙题 考率如何贪心,我们把黑色的条延长$s$,白色的缩短$ ...
- Noip模拟76 2021.10.14
T1 洛希极限 上来一道大数据结构或者单调队列优化$dp$ 真就没分析出来正解复杂度 正解复杂度$O(q+nm)$,但是据说我的复杂度是假的 考虑一个点转移最优情况是从它上面的一个反$L$形转移过来 ...
- Noip模拟51 2021.9.12
T1 茅山道术 考场上卡在了一个恶心的地方, 当时以为每次施法都会产生新的可以施法的区间,然后想都没细想, 认为不可做,甚至$dfs$也无法打,考后一问发现是自己想多了.. 新产生的区间对答案根本没有 ...
- Noip模拟81 2021.10.20
T1 语言 比较简单的题,然后就瞎写了,所以考场上就我一个写了线段树的,所以我的常数.... 所以就枚举动词的位置,找前面后面有没有出现$4$即可 1 #include<bits/stdc++. ...
- Noip模拟57 2021.9.20
规律总结:联考必爆炸 T1 2A 没$A$掉的大水题,但是是真的不知道$000$前面的$00$也算先导$0$,以后要长记性,这种东西不能再错了 再打三遍: $000$前面的$00$也算先导$0$ $0 ...
- Noip模拟70 2021.10.6
T1 暴雨 放在第一道的神仙题,不同的做法,吊人有的都在用线段树维护$set$预处理 我是直接$dp$的,可能代码的复杂度比那种的稍微小一点 设$f[i][j][p][0/1]$表示考虑了前$i$列, ...
- Noip模拟69 2021.10.5
考场拼命$yy$高精度结果没学好$for$循环痛失$50pts$,当场枯死 以后一定打对拍,要不考后会... T1 石子游戏 首先要知道典型的$NIM$博弈,就是说如果所有堆石子个数的异或和为$0$则 ...
- Noip模拟63 2021.9.27(考场惊现无限之环)
T1 电压机制 把题目转化为找那些边只被奇数环包含. 这样的话直接$dfs$生成一棵树,给每个点附上一个深度,根据其他的非树边都是返祖边 可以算出环内边的数量$dep[x]-dep[y]+1$,然后判 ...
- Noip模拟61 2021.9.25
T1 交通 考场上想了一个$NPC$.应该吧,是要求出图里面的所有可行的不重复欧拉路 无数种做法都无法解出,时间也都耗在这个上面的,于是就考的挺惨的 以后要是觉得当前思路不可做,就试着换一换思路,千万 ...
随机推荐
- 我用MRS-ClickHouse构建的用户画像系统,让老板拍手称赞
摘要:在移动互联网时代,用户数量庞大,标签数量众多,用户标签的数据量巨大.用户画像系统中,对于标签的存储和查询,不同的企业有不同的实现方案.当前主流的实现方案采用ElasticSearch方案.但基于 ...
- Java 语法学习2
Java基础语法二 类型转换 public class demo03 { public static void main(String[] args) { int i=128; byte a=(byt ...
- 【PHP数据结构】图的应用:最小生成树
在学习了图的基本结构和遍历方式后,我们再继续地深入学习一些图的基本应用.在之前的数据结构中,我们并没接触太多的应用场景,但是图的这两类应用确是面试或考试中经常出现的问题,而且出现的频率还非常高,不得不 ...
- PHP的那些魔术方法(二)
上文中介绍了非常常用并且也是面试时的热门魔术方法,而这篇文章中的所介绍的或许并不是那么常用,但绝对是加分项.当你能准确地说出这些方法及作用的时候,相信对方更能对你刮目相看. __sleep()与__w ...
- Nacos注册中心和配置中心流程原理
一.Nacos注册中心 1.服务启动后---->服务注册原理 springCloud集成Nacos实现原理: 服务启动时,在spring-cloud-commons包下 spring.facto ...
- Sentry 监控 - Search 搜索查询实战
系列 1 分钟快速使用 Docker 上手最新版 Sentry-CLI - 创建版本 快速使用 Docker 上手 Sentry-CLI - 30 秒上手 Source Maps Sentry For ...
- three.js 模型常用操作
场景: THREE.Scene(); 场景辅助坐标模型: THREE.AxesHelper(20); 相机: THREE.PerspectiveCamera()// 透视相机 THREE.Or ...
- 『GoLang』语法基础
标识符 字母或下划线开头 之后只能出现数字.字母.下划线 大小写敏感 Go语言关键字 break default func interface select case defer go map str ...
- vivo全球商城-营销价格监控方案的探索
一.背景 现在日常官网商城的运营中有一定概率出现以下两个问题: 1)优惠信息未对齐 官网商城促销优惠的类型越来越多,能影响最终用户实付价的优惠就有抢购.满减.优惠券.代金券等.实际业务操作中存在不同促 ...
- DeepDB:Learn From Data,not from Queries!
ABSTRACT DBMS典型学习方法的弊端:手机数据集的成本过高;工作方向或数据库发生改变时,必须重新收集数据.--------------解决:提出了一种新的数据驱动方式,直接支持工作负载和数据库 ...