当前位置: 首页 > news >正文

P2622 关灯问题

小小注解:

1.

vis:表示到达该状态的步数(min)+1, 

因为我们是从开始状态 穷举,所以每次到一个新状态(之前没有到过的状态)就是最小步数

如何判断是否是一个新状态呢,vis 知道,如果是新状态 vis=0;

另外,把开始状态设置为1,设置为 0 的话,程序就会把开始状态当作一个新状态,而开始状态当然不是一个新状态。

11.

开: 初始:1 0 1 0                                 关: 初始:1 0 1 0

           开: 1 1 0 0     (|)                               关: 1 1 0 0

        结果: 1 1 1 0                                        结果: 0 0 1 0

         初始 | 开 = 结果                                      ~关: 0 0 1 1     (&)

                                                                       初始 &(~ 关) = 结果 

111.

开始状态的得到:

例: n=4时;开始状态:1 1 1 1,即 (1<<n)-1 ;

注意:括号不能省,以为 1<<n-1 = 1<<(n-1);

#include<iostream>
#include<queue>
using namespace std;
int a[3300],b[3300]; //开灯 关灯 一个操作拆成两个 分别存在 a b中
int vis[3300];    //到达该状态的步数+1; 
//对于一种状态 1改灯开 0关
int main(){int n,m; cin>>n>>m;for(int i=0;i<m;i++)for(int j=0;j<n;j++){int x; scanf("%d",&x);a[i]<<=1; b[i]<<=1;if(x==1)  b[i]++;if(x==-1) a[i]++; }queue<int>q;q.push((1<<n)-1);vis[(1<<n)-1]=1;while(q.size()){int num=q.front(); q.pop();for(int i=0;i<m;i++){int temp=num|a[i];temp=temp&(~b[i]);if(vis[temp]) continue;vis[temp]=vis[num]+1; q.push(temp);if(temp==0){printf("%d",vis[0]-1); return 0;}}}printf("-1");return 0;
}

http://www.lryc.cn/news/345553.html

相关文章:

  • 从头开始的建材类电商小程序开发指南
  • 数据结构中的栈(C语言版)
  • (贪心05) 无重叠区间 划分字母区间 合并区间
  • 简单网络管理协议(SNMP)入门
  • leetcode解题思路分析(一百五十七)1366 - 1372 题
  • 药物代谢动力学学习笔记
  • IDEA中git的常用操作(保姆级教学)
  • 保研面试408复习 3——操作系统
  • 【代码随想录37期】Day02 有序数组的平方、长度最小的子数组、螺旋矩阵Ⅱ(施工中)
  • 通俗的理解网关的概念的用途(三):你的数据包是如何到达下一层的
  • 基于Springboot的校运会管理系统(有报告)。Javaee项目,springboot项目。
  • USP技术提升大语言模型的零样本学习能力
  • 前端安全防护实战:XSS、CSRF防御与同源策略详解(react 案例)
  • 2024C题生物质和煤共热解问题的研究 详细思路
  • 智慧旅游引领未来风尚,科技助力旅行更精彩:科技的力量推动旅游业创新发展,为旅行者带来更加便捷、高效和智能的旅行服务
  • 十.吊打面试官系列-Tomcat优化-通过压测Tomcat调优实战
  • JVM调优—减少FullGC
  • 力扣 256. 粉刷房子 LCR 091. 粉刷房子 python AC
  • C++STL细节,底层实现,面试题04
  • Linux查看Oracle数据库的环境变量
  • pg数据库学习知识要点分析-1
  • 【Web】CTFSHOW 七夕杯 题解
  • react native 设置屏幕锁定
  • 探索 IPv6 协议:互联网的新一代寻址
  • Ubuntu意外断电vmdk损坏--打不开磁盘“***.vmdk”或它所依赖的某个快照磁盘。
  • 202466读书笔记|《一天一首古诗词》——借问梅花何处落,风吹一夜满关山
  • 如何调用本地ollama的http请求接口
  • 【C】190 颠倒二进制位
  • 蓝桥杯备战5.图书管理员
  • 微型显示器可以实时监测大脑活动