P2962 [USACO09NOV]灯Lights

题目描述

Bessie and the cows were playing games in the barn, but the power was reset and the lights were all turned off. Help the cows get all the lights back on so they can resume their games.

The N (1 <= N <= 35) lights conveniently numbered 1..N and their switches are arranged in a complex network with M (1 <= M <= 595) clever connection between pairs of lights (see below).

Each light has a switch that, when toggled, causes that light -- and all of the lights that are connected to it -- to change their states (from on to off, or off to on).

Find the minimum number of switches that need to be toggled in order to turn all the lights back on.

It's guaranteed that there is at least one way to toggle the switches so all lights are back on.

贝希和她的闺密们在她们的牛棚中玩游戏。但是天不从人愿,突然,牛棚的电源跳闸了,所有的灯都被关闭了。贝希是一个很胆小的女生,在伸手不见拇指的无尽的黑暗中,她感到惊恐,痛苦与绝望。她希望您能够帮帮她,把所有的灯都给重新开起来!她才能继续快乐地跟她的闺密们继续玩游戏! 牛棚中一共有N(1 <= N <= 35)盏灯,编号为1到N。这些灯被置于一个非常複杂的网络之中。有M(1 <= M <= 595)条很神奇的无向边,每条边连接两盏灯。 每盏灯上面都带有一个开关。当按下某一盏灯的开关的时候,这盏灯本身,还有所有有边连向这盏灯的灯的状态都会被改变。状态改变指的是:当一盏灯是开著的时候,这盏灯被关掉;当一盏灯是关著的时候,这盏灯被打开。 问最少要按下多少个开关,才能把所有的灯都给重新打开。 数据保证至少有一种按开关的方案,使得所有的灯都被重新打开。

输入输出格式

输入格式:

  • Line 1: Two space-separated integers: N and M.

  • Lines 2..M+1: Each line contains two space-separated integers representing two lights that are connected. No pair will be repeated.

输出格式:

  • Line 1: A single integer representing the minimum number of switches that need to be flipped in order to turn on all the lights.

输入输出样例

输入样例#1:

5 6
1 2
1 3
4 2
3 4
2 5
5 3

输出样例#1:

3

说明

There are 5 lights. Lights 1, 4, and 5 are each connected to both lights 2 and 3.

Toggle the switches on lights 1, 4, and 5.

思路:meet in the middle

蒟蒻实在不会HZWER大神

#include<map>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
map<long long,int>mp;
int n,m;
int mid,flag,minn=0x7f7f7f7f;
long long ed,qwq[40],mmp[40];
void dfs(int x,long long now,int step){if(x==mid+1){if(now==ed)minn=min(step,minn);if(!flag){int tmp=mp[now];if(!tmp||tmp>step)mp[now]=step;}else{int tmp=mp[ed-now];if(!tmp)    return ;minn=min(tmp+step,minn);}return ;}dfs(x+1,now,step);dfs(x+1,now^qwq[x],step+1);
}
int main(){mmp[1]=1;for(int i=2;i<=40;i++)mmp[i]=mmp[i-1]<<1;scanf("%d%d",&n,&m);ed=mmp[n+1]-1;for(int i=1;i<=m;i++){int x,y;scanf("%d%d",&x,&y);qwq[x]+=mmp[y];qwq[y]+=mmp[x];}for(int i=1;i<=n;i++)qwq[i]+=mmp[i];mid=n/2;dfs(1,0,0);flag=1;mid=n;dfs(n/2+1,0,0);cout<<minn;
}

转载于:https://www.cnblogs.com/cangT-Tlan/p/7588489.html

洛谷 P2962 [USACO09NOV]灯Lights相关推荐

  1. 折半搜索+洛谷 P2962 [USACO09NOV]Lights G

    题意: 有 n盏灯,每盏灯与若干盏灯相连,每盏灯上都有一个开关,如果按下一盏灯上的开关,这盏灯以及与之相连的所有灯的开关状态都会改变.一开始所有灯都是关着的,你需要将所有灯打开,求最小的按开关次数.( ...

  2. P2962 [USACO09NOV]灯Lights

    贝希和她的闺密们在她们的牛棚中玩游戏.但是天不从人愿,突然,牛棚的电源跳闸了,所有的灯都被关闭了.贝希是一个很胆小的女生,在伸手不见拇指的无尽的黑暗中,她感到惊恐,痛苦与绝望.她希望您能够帮帮她,把所 ...

  3. 洛谷——P1876 开灯

    P1876 开灯 题目背景 该题的题目是不是感到很眼熟呢? 事实上,如果你懂的方法,该题的代码简直不能再短. 但是如果你不懂得呢?那...(自己去想) 题目描述 首先所有的灯都是关的(注意是关!),编 ...

  4. 洛谷——P1161 开灯

    P1161 开灯 题目描述 在一条无限长的路上,有一排无限长的路灯,编号为1,2,3,4,-1,2,3,4,-. 每一盏灯只有两种可能的状态,开或者关.如果按一下某一盏灯的开关,那么这盏灯的状态将发生 ...

  5. Java 洛谷 P1161 开灯

    文章链接:https://www.luogu.com.cn/problem/P1161 代码如下: package com.gxuwz.yixin;import java.util.Scanner;/ ...

  6. 洛谷 深基 第1部分 语言入门 第5章 数组与数据批量存储

    P1428 小鱼比可爱 小鱼比可爱 - 洛谷 P1427 小鱼的数字游戏 小鱼的数字游戏 - 洛谷 P5727 [深基5.例3]冰雹猜想 [深基5.例3]冰雹猜想 - 洛谷 P5727 [深基5.例3 ...

  7. 洛谷刷题C语言:【Mc生存】经验值、开灯、乘积最大3、三角函数、电梯里的爱情

    记录洛谷刷题QAQ 一.[Mc生存]经验值 题目背景 初一福利第2弹... 题目描述 话说 clearman 在 MC 世界开了个祥艺奶牛场,用熔浆.TNT 等丧心病狂的折磨牛,获取牛肉.牛奶等刷经验 ...

  8. 对于洛谷提高试炼场-动态规划篇的爆破

    题外话 由于本蒟蒻的动态规划实在是太弱啦,所以有必要爆破一下洛谷提高试炼场.里面有很多非常好,难度也合适的动态规划题--(然而你还是抄了不少题解) niconiconi~让我们一起开始爆破吧. lv- ...

  9. 洛谷千题复习计划(一)(Codeforces + AtCoder)

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 每天花一个小时简单复习一下我写过的洛谷的题目! 虽然还没有到千题,但是快了(等我复习完这些以后我 lu ...

最新文章

  1. C++八皇后拼图,打印所有的算法(附完整源码)
  2. QtQuick 中的 qml 与 Qt 的 C++
  3. 阿里云设置域名解析到主机ip
  4. 从V1到V4,让你读懂YOLO原理——深度AI科普团队
  5. Linux 下定时文件crontab配置
  6. [leetcode]Next Greater Element
  7. .net|dotnet应聘人员应该掌握的知识点
  8. 用python实现房贷计算器
  9. Dissect Eclipse Plugin Framework
  10. 网易云课堂Java应用基础:入门篇
  11. C语言学习笔记[第11天]
  12. Android的绘画软件,可以画漫画的软件有那些?你们要的安卓绘画软件,拿走吧!...
  13. 2017 ACM Arabella Collegiate Programming Contest(solved 11/13)
  14. OSChina 周六乱弹 ——这么桃色的故事,让张老汉讲述……
  15. C++ 类的简单使用
  16. ROS入门的基本操作
  17. java owc_vbscript ms owc 封裝代码
  18. MySQL密码正确却登录失败
  19. 解决win11 ms-windows-store无法打开商店
  20. 关于LabVIEW中的“值”与“值(信号)”属性

热门文章

  1. android2.2智能手机,Jelly 2:全球最小的Android 10 4G智能手机
  2. 网站优化与seo的方法(seo的优化基础)
  3. android wear 神奇宝贝,宝可梦Home安卓版下载_宝可梦Home手机app官方版(Pokemon Home) v1.0.3-安族游戏网...
  4. [转帖]国之魂,民之魂(硬骨头六连16勇士的最后一张照片)
  5. python 视频加字幕_Python追风者之视频编辑moviepy
  6. 超火壁纸!隐藏 Dock 栏+AirTag 渐变
  7. 别让拖延毁掉你自己 | 《拖延心理学》全书解读
  8. 亲测linux系统安装mysql5.7.22
  9. React报错:Error: Too many re-renders. React limits the number of renders to prevent an infinite loop.
  10. linux系统盘ssd,Linux系统下如何使用SSD固态硬盘