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

费解的开关(bfs + 哈希表 or 递推)

题目描述:

25盏灯排成一个5x5的方形。每一个灯都有一个开关,游戏者可以改变它的状态。每一步,游戏者可以改变某一个灯的状态。游戏者改变一个灯的状态会产生连锁反应:和这个灯上下左右相邻的灯也要相应地改变其状态。

我们用数字“1”表示一盏开着的灯,用数字“0”表示关着的灯。

主要思想:每一行的暗灯都由下面一行去点亮。

第一步我们先要去枚举第一行的所有按法

枚举第一行的所有按法是用来减少步数的,如果从第二行开始其实就已经固定了最后的答案,这样的解不一定是最少的甚至可能超出范围而没有解。

枚举第一行的意义是:不需要在意第一行的灯是灭是暗,只需把第一行的按法枚举一遍,也就是我们说的 “操作”,每个位置都有两种选择,按(用1表示)或者不按(用0表示),遍历这32种操作引发的情况,每一次再通过res = min(res, step);把最小步数存一下,就能找到最优解

步骤:

1️⃣枚举第一行时:1表示按一下,0表示不按
2️⃣在遍历整个矩阵时:1是灯亮,0是灯灭
3️⃣memcpy 可以用来复制数组,这里是先把原数组备份一下,然后对本数组操作,本次操作结束后,要再把备份数组还原回来,再进行下一次操作

代码:
#include <bits/stdc++.h>
using namespace std;const int N = 6;char g[N][N],backup[N][N];
int dx[] = {-1,0,1,0,0},dy[] = {0,1,0,-1,0};void turn(int x,int y)
{for (int i = 0;i < 5;i++){int ax = x + dx[i],ay = y + dy[i];if(ax < 0 || ax > 4 || ay < 0 || ay > 4) continue;g[ax][ay] ^= 1;}
}int main()
{int t;cin >> t;while (t--) 
http://www.lryc.cn/news/506510.html

相关文章:

  • C语言——实现求出最大值
  • 基于微信小程序的短视频系统(SpringBoot)+文档
  • Flutter 中 Sliver 的各种装饰器介绍与使用
  • 电感的基本概念
  • linux基于systemd自启守护进程 systemctl自定义服务傻瓜式教程
  • HTTP协议和接口测试详解
  • vue3【实战】定义全局方法(两种方案)
  • 基于JavaScript的DBUtils增删改查操作实验
  • 初学stm32 --- 系统时钟配置
  • 实现星星评分系统
  • 数据库建模工具 PDManer
  • 后台运维操作建议
  • NX二次开发调用内部函数设置对象穿透显示DSS_ATTR_set_show_through
  • ubuntu16.04ros-用海龟机器人仿真循线系统
  • 解决Ubuntu 20.04上编译OpenCV 3.2时遇到的stdlib.h缺失错误
  • HTML综合案例
  • TanStack——为现代前端开发提供高性能和灵活的工具
  • Java爬虫️ 使用Jsoup库进行API请求有什么优势?
  • React源码02 - 基础知识 React API 一览
  • COMSOL with Matlab
  • 【报表查询】.NET开源ORM框架 SqlSugar 系列
  • PostgreSQL数据库访问限制详解
  • 【test linux】创建一个ext4类型的文件系统
  • 如何在繁忙的生活中找到自己的节奏?
  • AI-PR曲线
  • Guava 提供了集合操作 `List`、`Set` 和 `Map` 三个工具类
  • 深入解析 Elasticsearch 集群配置文件参数
  • WebMvcConfigurer和WebMvcConfigurationSupport(MVC配置)
  • 用 javascript 来回答宇宙外面是什么
  • 我的性能优化经验