枚举时对数组操——三刷AcWing 95. 费解的开关

简介: 枚举时对数组操——三刷AcWing 95. 费解的开关

95. 费解的开关 - AcWing题库


这次三刷主要是试了下枚举情况操作数组时,操作复制了原数组的新数组,而不是备份原数组,操作原数组,还原原数组,第一次使用略有卡壳


/ 卡壳点:枚举时对数组操作,如果是对复制出来的数组操作,一定要在开始枚举但还没开始操作的时候来复制数组

// 如果是对备份后的原数组操作,只要在操作前备份原数组,然后在一轮枚举的末尾还原原数组就可以了

#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
using namespace std;
const int N = 6;
char f[N][N],backup[N][N];
void turn(int x,int y){
    int dx[] = {0,0,0,1,-1},dy[] = {1,-1,0,0,0};
    for(int i = 0;i < 5;i++){
        int a = x + dx[i] , b = y + dy[i];
        if(a < 0 || a > 4 || b < 0 || b > 4)continue;
        backup[a][b] ^= 1;
    }
}
int main(){
    int t;
    cin >> t;
    while(t--){
        for(int i  = 0;i < 5;i++){
            for(int j = 0;j < 5;j++){
                cin >> f[i][j];
            }
        }
        int res = 0x3f3f3f3f;
        for(int op = 0;op < 1 << 5;op++){
            // 卡壳点:枚举时对数组操作,如果是对复制出来的数组操作,一定要在开始枚举但还没开始操作的时候来复制数组
            // 如果是对备份后的原数组操作,只要在操作前备份原数组,然后在一轮枚举的末尾还原原数组就可以了
            memcpy(backup,f,sizeof f);
            int step = 0;
            for(int i = 0;i < 5;i++){
                if(op >> i & 1){
                    step++;
                    turn(0,i);
                }
            }
            for(int i = 0;i < 4;i++){
                for(int j = 0;j < 5;j++){
                    if(backup[i][j] == '0') {
                        step++;
                        turn(i+1,j);
                    }
                }
            }
            bool dark = false;
            for(int i = 0;i < 5;i++){
                if(backup[4][i] == '0'){
                    dark = true;
                    break;
                }
            }
            if(!dark) res = min(step,res);
        }
        if(res > 6) res = -1;
        cout << res << endl;
    }
    return 0;
}

解题思路:


// 数据范围

// 0<n≤500,随便操作

// 游戏者改变一个灯的状态会产生连锁反应:和这个灯上下左右相邻的灯也要相应地改变其状态。开关灯问题,

// 只影响附近一格的开关灯,可以递推

// // 递推的第一行决定了后续的结果,所以要枚举对第一行的操作来改变结果。 枚举中对数组操作前要进行备份

// 只有0,1两种字符,可用位运算枚举


// 我们用数字 1

// 表示一盏开着的灯,用数字 0

// 表示关着的灯。 灯的状态


// 编写程序判断游戏者是否可能在 6

// 步以内使所有的灯都变亮。它表示对于输入数据中对应的游戏状态最少需要几步才能使所有灯变亮。 灯亮判断,最小值找寻


// 对于某一个游戏初始状态,若 6

// 步以内无法使所有灯变亮,则输出 −1 无解输出-1 枚举完要一个六步判断


// 3

// 00111

// 01011

// 10001

// 11010

// 11100


// 11101

// 11101

// 11110

// 11111

// 11111


// 01111

// 11111

// 11111

// 11111

// 11111 输入无空格,字符读取


目录
相关文章
|
7月前
|
开发者
鸿蒙开发:如何实现列表吸顶
鸿蒙当中实现一个列表吸顶,很是简单,官方为我们提供了ListItemGroup组件,使用它,便可以轻松搞定
144 6
鸿蒙开发:如何实现列表吸顶
|
算法 Java
在Java编程中,关键字和保留字是基础且重要的组成部分,正确理解和使用它们
【10月更文挑战第13天】在Java编程中,关键字和保留字是基础且重要的组成部分。正确理解和使用它们,如class、int、for、while等,不仅能够避免语法错误,还能提升代码的可读性和执行效率。本指南将通过解答常见问题,帮助你掌握Java关键字的正确使用方法,以及如何避免误用保留字,使你的代码更加高效流畅。
146 3
|
存储 监控 安全
阿里云的主要云产品和服务有哪些?
阿里云提供的云产品和服务多达几百款,从分类上来说主要分为弹性计算、数据库、存储、网络、大数据、人工智能、云安全、互联网中间件、云分析、管理与监控、应用服务、视频服务、移动服务、云通信、域名与网站、行业解决方案等,每个分类下的主要云产品和服务如下:
4351 0
|
应用服务中间件 nginx 数据安全/隐私保护
|
5天前
|
云安全 监控 安全
|
2天前
|
存储 机器学习/深度学习 人工智能
打破硬件壁垒!煎饺App:强悍AI语音工具,为何是豆包AI手机平替?
直接上干货!3000 字以上长文,细节拉满,把核心功能、使用技巧和实测结论全给大家摆明白,读完你就知道这款 “安卓机通用 AI 语音工具"——煎饺App它为何能打破硬件壁垒?它接下来,咱们就深度拆解煎饺 App—— 先给大家扒清楚它的使用逻辑,附上“操作演示”和“🚀快速上手不踩坑 : 4 条核心操作干货(必看)”,跟着走零基础也能快速上手;后续再用真实实测数据,正面硬刚煎饺 App的语音助手口令效果——创建京东「牛奶自动下单神器」口令 ,从修改口令、识别准确率到场景实用性,逐一测试不掺水,最后,再和豆包 AI 手机语音助手的普通版——豆包App对比测试下,简单地谈谈煎饺App的能力边界在哪?
|
10天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1180 7
|
1天前
|
人工智能
自动化读取内容,不会写爆款的普通人也能产出好内容,附coze工作流
陌晨分享AI内容二创工作流,通过采集爆款文案、清洗文本、智能改写,实现高效批量生产。五步完成从选题到输出,助力内容创作者提升效率,适合多场景应用。
205 104