第一周 枚举:1.画家问题

总时间限制:
1000ms
内存限制:
65536kB
描述
有一个正方形的墙,由N*N个正方形的砖组成,其中一些砖是白色的,另外一些砖是黄色的。Bob是个画家,想把全部的砖都涂成黄色。但他的画笔不好使。当他用画笔涂画第(i, j)个位置的砖时, 位置(i-1, j)、 (i+1, j)、 (i, j-1)、 (i, j+1)上的砖都会改变颜色。请你帮助Bob计算出最少需要涂画多少块砖,才能使所有砖的颜色都变成黄色。
输入
第一行是个整数t(1 <= t <= 20),表示要测试的案例数。然后是t个案例。每个案例的首行是一个整数n (1<= n <= 15),表示墙的大小。接下来的n行表示墙的初始状态。每一行包含n个字符。第i行的第j个字符表示位于位置(i,j)上的砖的颜色。"w"表示白砖,"y"表示黄砖。
输出
每个案例输出一行。如果Bob能够将所有的砖都涂成黄色,则输出最少需要涂画的砖数,否则输出"inf"。
样例输入
2
3
yyy
yyy
yyy
5
wwwww
wwwww
wwwww
wwwww
wwwww 
样例输出
0
15 
 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cmath>
 4 using namespace std;
 5
 6 int t = 0;
 7 int n = 0;
 8 char col[20];
 9 bool c[20][20] = {0};
10 bool colored[20][20] = {0};
11 bool swit[20][20] = {0};
12
13 void changeswit(int a, int b)
14 {
15     colored[a][b] = !colored[a][b];
16     colored[a - 1][b] = !colored[a - 1][b];
17     colored[a + 1][b] = !colored[a + 1][b];
18     colored[a][b - 1] = !colored[a][b - 1];
19     colored[a][b + 1] = !colored[a][b + 1];
20 }
21
22
23 int main()
24 {
25     scanf("%d", &t);
26     for(int ti = 1; ti <= t; ++ti)
27     {
28         int sum = 0;
29         scanf("%d", &n);
30         int min = n * n + 1;
31         for(int i = 1; i <= n; ++i)
32         {
33             scanf("%s", col);
34             for(int j = 1; j <= n; ++j)
35             {
36                 if(col[j - 1] == ‘y‘) c[i][j] = 1;
37                 else c[i][j] = 0;
38             }
39         }
40         for(int k = 0; k < pow(2.0, n); k++)
41         {
42             for(int i = 1; i <= n; i++)
43                 for(int j = 1; j <= n; j++)
44                 {
45                     colored[i][j] = c[i][j];
46                 }
47             for(int i = 1; i <= n; i++)
48             {
49                 swit[1][i] = (k>>(i - 1)) & 1;
50                 if(swit[1][i])
51                 {
52                     changeswit(1, i);
53                     sum++;
54                 }
55             }
56             for(int i = 2; i <= n; i++)
57                 for(int j = 1; j <= n; j++)
58                     if(!colored[i - 1][j])
59                     {
60                         swit[i][j] = 1;
61                         sum++;
62                         changeswit(i, j);
63                     }
64             int mark = 0;
65             for(int j = 1; j <= n; j++)
66                 if(!colored[n][j]) mark = 1;
67             if(!mark && sum < min) min = sum;
68             sum = 0;
69         }
70         if(min != n*n + 1) printf("%d\n",min);
71         else printf("inf\n");
72     }
73     return 0;
74 }         

时间: 2024-10-30 02:30:06

第一周 枚举:1.画家问题的相关文章

程序设计与算法(二)算法基础》《第一周 枚举》熄灯问题 POJ-1222

https://www.cnblogs.com/huashanqingzhu/p/7278930.html http://bailian.openjudge.cn/practice/12221222:EXTENDED LIGHTS OUT 这道题我花了比较多的时间才想清楚,比较难想的地方在第一行的枚举,假设第一行6个元素是 0 1 0 1 0 1, 一盏灯只有亮和灭两个状态,每盏灯只有两个操作,按下开关与不按开关,我之前以为枚举的是0~63,即0000 0000 ~1111 1111, 这种想法

网易云课堂_C语言程序设计进阶_第一周:数据类型:整数类型、浮点类型、枚举类型

C语言程序设计进阶_第一周:数据类型:整数类型.浮点类型.枚举类型 1.0数据类型 1.1整数类型 1.2浮点类型 1.3逻辑类型 1.4类型转换和条件运算 1.0数据类型 1 整数 char(%c), short, int(%d), long(%ld), long long(C99) 2 浮点数 float(%f), double(%lf), long double(C99) 3 逻辑 bool(C99) 4 指针 5 自定义类型 所表达的数的范围:char<short<int<flo

20155336 2016-2017-2《JAVA程序设计》第一周学习总结

# 20155336  2016-2017-2<JAVA程序设计>第1周学习总结 ## 教材学习内容总结 开学的第一周,带着些许的欣喜和好奇,听完了老师的第一堂课.说心里话学习JAVA仿佛观看一部英文影视作品一样头疼, 因为总会有许许多多相似的名字让你记得晕头转向.JAVA也是一样,什么JVM啊JRE啊JDK啊 (/(ㄒoㄒ)/~~)  等等一系列 的英文缩写,让人心神意乱~~但总体上对JAVA有了一个初步的了解.通过课上老师的介绍以及课下对JAVA书第一章的浏览, 我简单的了解了JAVA艰辛

20145216 史婧瑶《信息安全系统设计基础》第一周学习总结

20145216 <信息安全系统设计基础>第一周学习总结 教材学习内容总结 Linux基础 1.ls命令 ls或ls .显示是当前目录的内容,这里“.”就是参数,表示当前目录,是缺省的可以省略.我们可以用ls -a .显示当前目录中的所有内容,包括隐藏文件和目录.其中“-a” 就是选项,改变了显示的内容.如图所示: 2.man命令 man命令可以查看帮助文档,如 man man : 若在shell中输入 man+数字+命令/函数 即可以查到相关的命令和函数:若不加数字,那man命令默认从数字较

第一周例行报告

PSP 内容 类别 预计时长 开始时间 结束时间 中断时间 实际花费时间 第一周作业一 写作 1h 2017-9-7  19:25 2017-9-7  20:18  回复微信消息5min 48min 看<构建之法> 阅读 一周,每天1h30min 2017-9-7  21:35 2017-9-10   每天抽空看一些 没有具体时间 采访记录 写作 1h 2017-9-9   20:46 2017-9-9 22:04  一边写一边吃火龙果  1h左右 构建之法读后感 写作 1h 2017-9-1

《嵌入式设计》第一周学习总结

<嵌入式设计>第一周学习总结 学习时遇到的主要问题 1.运行环境未及时安装 2.命令不熟练 3.上课状态不好 解决方法 1.及时安装环境并熟悉运行 2.参考Linux操作系统实用教程并百度一些问题的解决办法 3.及时调整自己状态 主要学习内容 Linux一些简单基本的操作, 用.c文件输出hello word 用vi test.c 创建.c文件 #include <stdio.h> int main(){ printf("hello word\n"); } 并用

20145311 《信息安全系统设计基础》第一周学习总结

20145311 <信息安全系统设计基础>第一周学习总结 教材学习内容总结 常用的部分命令 CTRL+SHIFT+T:新建标签页,编程时有重要应用: ALT+数字N:终端中切换到第N个标签页,编程时有重要应用: Tab:终端中命令补全,当输入某个命令的开头的一部分后,按下Tab键就可以得到提示或者帮助完成: CTRL+C:中断程序运行 Ctrl+D:键盘输入结束或退出终端 Ctrl+S: 暂定当前程序,暂停后按下任意键恢复运行 Ctrl+A: 将光标移至输入行头,相当于Home键 Ctrl+E

2016-7第一周工作总结

姓名 王奈 时间 第一周工作总结 学习内容 经过了一周的开发与改进,我们的easy工大已经初见成果.这一周,我们完成了:界面的重新设计,数据获取正确性修改,以及吐槽墙功能的实现等等.我的工作就是文档记录,在这过程中,我能够记录我们项目进步的点点滴滴,记录它是如何一步一步走到现在的样子,就像看到了软件的成长过程一样. 除此之外,我还完成了一个嵌入式开发项目的初步实现,学习了嵌入式编程的原则以及优化方法.如同软工所要求的一样,我在嵌入式开发的过程中也使用了文档记录的方法来管理我们的项目进度,这样一来

JS第一周总结1

JS第一周总结 这周我学习了JS的基础部分,大致分为了: a.基础变量及数据类型 b.特殊数据类型 c.JS基础语句类型 d.BOM操作 e.DOM操作 ###基础变量###     1.首先给变量取名,取名规范有3点:         1.变量首字符必须是字母或者美元符号$.下划线_ 三者之一.         2.变量名字中不能包括特殊符号,比如空格.加减号等符号.         3.变量中不能包括JS中的关键字,比如var之类的. 2.取好名字之后,我们需要将这个变量定义出来,并且赋值给