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;
}

  

最新文章

  1. 数据库助手类 DBHelper
  2. 《构建之法》阅读有疑 与 个人Week1作业
  3. java整合spring和hadoop HDFS
  4. 单独批次性任务采用MySQL定时器解决需求
  5. 练习2 C - 成绩转换
  6. 建议别买三星Gear:半电脑产品 设计糟糕
  7. LeetCode——Binary Tree Level Order Traversal II
  8. grunt打包过程中的注意点
  9. ADS2008 安装方法详解及文件下载
  10. cocos2d-x-2.2的SimpleAudioEngine::sharedEngine()-&amp;gt;playEffect()计划中断bug
  11. 流水线技术原理和Verilog HDL实现(转)
  12. html5新特性与HTML的区别
  13. T-SQL的进阶:超越基本级别3:构建相关子查询——701小组
  14. C# ref与out
  15. 剑指Offer——知识点储备-数据库基础
  16. java通过Access_JDBC30读取access数据库时无法获取最新插入的记录
  17. 【leetcode】 Merge Intervals
  18. Map集合遍历的四种方式理解和简单使用
  19. 安卓——BroadcastReceiver
  20. Mongodb Windows 集群

热门文章

  1. LINQ语句中的.AsEnumerable() 和 .AsQueryable()的区别
  2. 字符加密Cipher(bzoj 1031)
  3. 阅读ArrayBlockingQueue源码了解如何利用锁实现BlockingQueue
  4. 物联网平台设计心得:DateTimePicker实现选择联动
  5. ReactNative新手学习之路05 使用夜神模拟器调试ReactNative
  6. php get_class()函数
  7. 【swift学习笔记】二.页面转跳数据回传
  8. WPF绘制简单常用的Path
  9. 第五次团队作业——【Alpha版本】随笔汇总
  10. Eclipse+maven创建webapp项目&lt;二&gt;(转)