BZOJ 1770: [Usaco2009 Nov]lights 燈
2024-10-01 06:49:56
Description
一个图,对一个点进行操作会改变这个点及其相邻的点的状态,问全部变成黑色至少需要几次.数据保证有解.
Sol
Meet in middle.
我一开始写个高斯消元,发现有两个点过不去,原因是没有处理好自由元,应该在DFS的时候回带所有解,然后就弃疗了.
然后发现这个其实可以暴力,就是 Meet in middle...
先把前一半暴力枚举存到 map 里,后一半再枚举,从 map 中找补集.
复杂度 \(O(2^{13})\)
Code
/**************************************************************
Problem: 1770
User: BeiYu
Language: C++
Result: Accepted
Time:416 ms
Memory:5384 kb
****************************************************************/ #include <cstdio>
#include <map>
#include <iostream>
using namespace std; typedef long long LL;
const int N = 40; int n,m,ans=N;
LL state,pow2[N],a[N];
map< LL,int > mp; void DFS1(int l,int r,int w,LL s){
if(l>r){ if(mp.find(s)==mp.end() || mp[s]>w) mp[s]=w;return; }
DFS1(l+1,r,w,s);
DFS1(l+1,r,w+1,s^a[l]);
}
void DFS2(int l,int r,int w,LL s){
if(l>r){ if(mp.find(state^s)!=mp.end()) ans=min(ans,w+mp[state^s]);return; }
DFS2(l+1,r,w,s);
DFS2(l+1,r,w+1,s^a[l]);
}
int main(){
cin>>n>>m;
pow2[0]=1LL;
for(int i=1;i<=n;i++) pow2[i]=pow2[i-1]<<1;
for(int i=0;i<n;i++) a[i]|=pow2[i],state|=pow2[i];
for(int i=1,u,v;i<=m;i++){
cin>>u>>v;
u--,v--;
a[u]|=pow2[v],a[v]|=pow2[u];
}
DFS1(0,min(n-1,n/2),0,0);
DFS2(min(n-1,n/2)+1,n-1,0,0);
cout<<ans<<endl;
return 0;
}
最新文章
- 数据库助手类 DBHelper
- 《构建之法》阅读有疑 与 个人Week1作业
- java整合spring和hadoop HDFS
- 单独批次性任务采用MySQL定时器解决需求
- 练习2 C - 成绩转换
- 建议别买三星Gear:半电脑产品 设计糟糕
- LeetCode——Binary Tree Level Order Traversal II
- grunt打包过程中的注意点
- ADS2008 安装方法详解及文件下载
- cocos2d-x-2.2的SimpleAudioEngine::sharedEngine()-&;gt;playEffect()计划中断bug
- 流水线技术原理和Verilog HDL实现(转)
- html5新特性与HTML的区别
- T-SQL的进阶:超越基本级别3:构建相关子查询——701小组
- C# ref与out
- 剑指Offer——知识点储备-数据库基础
- java通过Access_JDBC30读取access数据库时无法获取最新插入的记录
- 【leetcode】 Merge Intervals
- Map集合遍历的四种方式理解和简单使用
- 安卓——BroadcastReceiver
- Mongodb Windows 集群
热门文章
- LINQ语句中的.AsEnumerable() 和 .AsQueryable()的区别
- 字符加密Cipher(bzoj 1031)
- 阅读ArrayBlockingQueue源码了解如何利用锁实现BlockingQueue
- 物联网平台设计心得:DateTimePicker实现选择联动
- ReactNative新手学习之路05 使用夜神模拟器调试ReactNative
- php get_class()函数
- 【swift学习笔记】二.页面转跳数据回传
- WPF绘制简单常用的Path
- 第五次团队作业——【Alpha版本】随笔汇总
- Eclipse+maven创建webapp项目<;二>;(转)