PTA 2813:画家问题(熄灯问题)

有一个正方形的墙,由NN个正方形的砖组成,其中一些砖是白色的,另外一些砖是黄色的。Bob是个画家,想把全部的砖都涂成黄色。但他的画笔不好使。当他用画笔涂画第(i,j)个位置的砖时, 位置(i−1,j)、 (i+1,j)、(i,j−1)、(i,j+1)上的砖都会改变颜色。请你帮助Bob计算出最少需要涂画多少块砖,才能使所有砖的颜色都变成黄色。

1-1.jpg

输入格式:

第一行是一个整数n (1≤n ≤16),表示墙的大小。接下来的n行表示墙的初始状态。每一行包含n个字符。第i行的第j个字符表示位于位置(i,j)上的砖的颜色。“w”表示白砖,“y”表示黄砖。

输出格式:

一行,如果Bob能够将所有的砖都涂成黄色,则输出最少需要涂画的砖数,否则输出“inf”。

输入样例:

在这里给出一组输入。例如:

5
wwwww
wwwww
wwwww
wwwww
wwwww

输出样例:

在这里给出相应的输出。例如:

15

熄灯问题没什么好方法,只能一层一层推导。

AC代码:

#indpude<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define endl "\n"const ll N = 1e1+7 ,M = 1e5+7;
ll n;
ll color[N][N],dp[N][N];ll pd(ll z){for(ll i = 1 ; i < z ; i ++)//尝试涂色,当前点的颜色由初始画板和涂色区推出 for(ll j = 1 ; j <= z ; j ++)dp[i+1][j]=(color[i][j]+dp[i-1][j]+dp[i][j-1]+dp[i][j]+dp[i][j+1])%2;for(ll i = 1 ; i <= z ; i ++)//由最后一行判断当前涂色能否成功 if(color[z][i] != (dp[z-1][i]+dp[z][i-1]+dp[z][i]+dp[z][i+1])%2)return M;ll sum=0;//算涂色次数 for(ll i = 1 ; i <= z ; i ++)for(ll j = 1 ; j <= z ; j ++)if(dp[i][j])sum++;return sum;
}ll found(ll x){ll sum = M ,cnt = 0 ,y;while(dp[1][x+1] < 1){cnt = pd(x);if(cnt < sum)sum=cnt;dp[1][1]++;y=1;while(dp[1][y] > 1){dp[1][y]=0;y++;dp[1][y]++;}}return sum;
}void solve(){memset(dp,0,sizeof dp);memset(color,0,sizeof color);cin >> n;for(ll i = 1 ; i <= n ; i ++)for(ll j = 1 ; j <= n ; j ++){char c;cin >> c;if(c == 'w')color[i][j]=1;}ll sum = found(n);sum == M ? cout << "inf" << endl : cout << sum << endl;return;
}int main(){ll t=1;//cin >> t;while(t --)solve();return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/806819.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

POSTGRESQL——存储过程调试

在 PostgreSQL 中调试存储过程&#xff08;通常指的是 PL/pgSQL 或其他过程语言编写的函数&#xff09;&#xff0c;如果不能或不想使用专门的 debug 模式或插件&#xff0c;可以通过以下几种方法进行辅助调试&#xff1a; 1. 使用 RAISE 语句输出调试信息 场景与示例&#x…

掌握判断IPv4地址是否正确的方法

在数字通信和互联网领域中&#xff0c;IPv4地址作为标识网络设备的核心元素&#xff0c;其正确性至关重要。一个有效的IPv4地址能够确保设备在网络中的正常通信和交互&#xff0c;而错误的IPv4地址则可能导致连接失败、通信中断甚至网络安全问题。因此&#xff0c;掌握判断IPv4…

学习笔记——C语言基本概念文件——(13)

1、文件操作 1.1、文件概念 文件&#xff1a;实现数据存储的载体 1.2、文件的分类 按照数据的组织形式分类&#xff1a; 1.字符文件/文本文件 2.二进制文件 按照用途分类&#xff1a; 1.系统文件 2.库文件--标准库文件/非标准库文件&#xff08;第三方库&#xff09; 3.用…

SQL注入sqli_labs靶场第二题

解题思路与第一题相同 ?id1 and 11 和?id1 and 12进行测试如果11页面显示正常和原页面一样&#xff0c;并且12页面报错或者页面部分数据显示不正常&#xff0c;那么可以确定此处为数字型注入。 联合查询&#xff1a; 猜解列名数量&#xff1a;3 ?id1 order by 4 判断回显…

防止邮箱发信泄露服务器IP教程

使用QQ邮箱,网易邮箱,189邮箱,新浪邮箱,139邮箱可能会泄露自己的服务器IP。 泄露原理&#xff1a;服务器通过请求登录SMTP邮箱服务器接口&#xff0c;对指定的收件人发送信息。 建议大家使用商业版的邮箱&#xff0c;比如阿里云邮箱发信等 防止邮件发信漏源主要关注的是确保邮件…

机器学习和深度学习--李宏毅 (笔记与个人理解)Day7

Day7 Regression Case study &#xff08;预测宝可梦的cp&#xff09; Regression 可以做什么&#xff1f; 股票预测 自动驾驶 推荐 预测宝可梦的cp&#xff08;能力类似这样的属性把&#xff09; 这里突然想到&#xff0c;是不是可以用洛克王国和赛尔号做事情哈哈 注意&#…

6种xinput1_3.dll丢失的解决办法,并探讨xinput1_3.dll丢失的原因及其属性。

xinput1_3.dll扮演着Visual C运行时库中不可或缺的角色&#xff0c;众多电脑软件都需依赖它以确保正常运行。 当您启动软件时&#xff0c;若遇到xinput1_3.dll无法执行代码的提示&#xff0c;可能会导致软件无法如常启动或运行。本文将向您介绍6种解决方案&#xff0c;并探讨xi…

Java基于微信小程序的乐室预约系统(V2.0),附源码

博主介绍&#xff1a;✌IT徐师兄、7年大厂程序员经历。全网粉丝15W、csdn博客专家、掘金/华为云//InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&#x1f3…

global.d.ts 无效问题解决

问题描述 和 src 同级目录有一个 types目录&#xff0c;其中包含 global.d.ts&#xff0c;如下 declare global {interface Window {config: {url: string;};} }在组件中访问 window.config x;ts显示此错误 Error:(10, 22) TS2339: Property config does not exist on typ…

WEB前端-倒计时练习

<body><div>距离2024年7月3日还有&#xff1a;<br><span id"d">0</span>天<span id"h">0</span>小时<span id"m">0</span>分钟<span id"s">0</span>秒</div>…

jQuery 数字金额转化为英文大写

示例&#xff1a;100转化为SAY ONE HUNDRED AND POINT ONLY //数字金额转换英文大写&#xff08;金额上线不能超过10亿&#xff09; var arr1new Array(""," THOUSAND"," MILLION"," BILLION") var arr2new Array("ZERO",&…

文章解读与仿真程序复现思路——电力系统自动化EI\CSCD\北大核心《新型电力系统多阶段输-储协同分布鲁棒规划》

本专栏栏目提供文章与程序复现思路&#xff0c;具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源…

【PHP系统学习】——Laravel框架数据库的连接以及数据库的增删改查的详细教程

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;开发者-曼亿点 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 曼亿点 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a…

蓝桥杯——考勤刷卡

题目 小蓝负责一个公司的考勤系统,他每天都需要根据员工刷卡的情况来确定 每个员工是否到岗。 当员工刷卡时,会在后台留下一条记录,包括刷卡的时间和员工编号,只 要在一天中员工刷过一次卡,就认为他到岗了。 现在小蓝导出了一天中所有员工的刷卡记录,请将所有到岗员工的员工编…

创建网络名称空间后的Linux幕后工作解析

Linux网络名称空间&#xff08;Network Namespace&#xff09;是一种强大的虚拟化技术&#x1f310;&#xff0c;允许用户隔离网络设备、IP地址、路由表等网络资源。这项技术在容器化和虚拟化领域发挥着关键作用&#xff0c;是构建现代云基础设施的基石之一⛅。当你创建一个新的…

ubuntu常用指令(1)

ls&#xff1a;列出当前目录中的文件和子目录pwd&#xff1a;显示当前工作路径cd /*&#xff1a;切换到指定目录mkdir file_name&#xff1a;创建新目录rmdir file_name&#xff1a;删除文件或目录cp file_name&#xff1a;复制文件或目录mv old_name new_name&#xff1a;重命…

无人机炸机后还能修复吗?

无人机炸机后是否还能修复&#xff0c;取决于炸机的具体情况和损坏程度。 一般来说&#xff0c;如果无人机的损坏比较严重&#xff0c;例如主要结构部件断裂或严重变形&#xff0c;电机、电池、电子设备等核心部件损坏&#xff0c;那么修复的难度和费用会比较高&#xff0c;可…

2024年华为OD机试真题-最大N个数与最小N个数的和-Python-OD统一考试(C卷)

题目描述: 给定一个数组,编写一个函数来计算它的最大N个数与最小N个数的和。你需要对数组进行去重。 说明: 数组中数字范围[0, 1000] 最大N个数与最小N个数不能有重叠,如有重叠,输入非法返回-1 输入非法返回-1 输入描述: 第一行输入M, M标识数组大小\n第二行输入M个数,标…

Threadlocal什么情况下会造成内存泄露?怎么避免?

ThreadLocal 在某些情况下可能会导致内存泄露&#xff0c;主要是由于线程的生命周期超过了预期而导致的。以下是一些可能导致 ThreadLocal 内存泄露的情况&#xff1a; 线程池的使用&#xff1a;如果在使用线程池的情况下&#xff0c;没有正确清理 ThreadLocal 变量&#xff0c…

Quanto: PyTorch 量化工具包

量化技术通过用低精度数据类型 (如 8 位整型 (int8)) 来表示深度学习模型的权重和激活&#xff0c;以减少传统深度学习模型使用 32 位浮点 (float32) 表示权重和激活所带来的计算和内存开销。 减少位宽意味着模型的内存占用更低&#xff0c;这对在消费设备上部署大语言模型至关…