1.链接地址:

http://bailian.openjudge.cn/practice/2813

http://poj.org/problem?id=1681

2.题目:

总时间限制:
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
来源
1681

3.思路:

此题思路与 OpenJudge 2811 熄灯问题 和 Poj 1222 EXTENDED LIGHTS OUT 一样,请查看以下

http://www.cnblogs.com/mobileliker/p/3548190.html

注意此题的区别是有可能出现不存在的情况,所以要多一个判断

4.代码:

 #include <iostream>
#include <cstdio>
#include <cstdlib>
#include <string>
#include <cstring> using namespace std; int main()
{
int i,j; int t;
cin>>t; int n;
int flag;
while(t--)
{
flag = ;
cin>>n; bool *arr_draw = new bool[(n + ) * (n + )];
bool *arr_draw_save = new bool[(n + ) * (n + )];
bool *arr_res = new bool[(n + ) * (n + )]; string str;
memset(arr_draw,,sizeof(bool) * (n + ) * (n + ));
for(i = ; i <= n; ++i)
{
cin>>str;
for(j = ; j <= n; ++j)
{
if(str[j-] == 'y') arr_draw[i * (n + ) + j] = false;
else arr_draw[i * (n + ) + j] = true;
}
}
memcpy(arr_draw_save,arr_draw,sizeof(bool) * (n + ) * (n + )); memset(arr_res + * (n + ),,sizeof(bool) * (n + ));
while()
{
for(i = ; i <= n; ++i)
{
for(j = ; j <= n; ++j)
{
arr_draw[(i - ) * (n + ) + j] ^= arr_res[i * (n + ) + j];
arr_draw[i * (n + ) + (j - )] ^= arr_res[i * (n + ) + j];
arr_draw[i * (n + ) + (j + )] ^= arr_res[i * (n + ) + j];
arr_draw[(i + ) * (n + ) + j] ^= arr_res[i * (n + ) + j];
arr_draw[i * (n + ) + j] ^= arr_res[i * (n + ) + j];
}
memcpy(&arr_res[(i + ) * (n + )],&arr_draw[i * (n + )],sizeof(bool) * (n + ));
}
for(i = ; i <= n; ++i) if(arr_draw[n * (n + ) + i]) break;
if(i > n) break;
else
{
memcpy(arr_draw,arr_draw_save,sizeof(bool) * (n + ) * (n + )); for(i = n; i > ; --i) if(!arr_res[ *(n + ) + i]) break;
while(i <= n) {arr_res[ * (n + ) + i] = !arr_res[ * (n + ) + i]; ++i;} for(i = ; i <= n; ++i) {if(arr_res[ * (n + ) + i]) break;}
if(i > n) {flag = ; break;}
}
} int count = ;
if(flag)
{
for(i = ; i <= n; ++i)
{
for(j = ; j <= n; ++j)
{
count += arr_res[i * (n + ) + j];
}
}
cout<<count<<endl;
}
else cout<<"inf"<<endl; delete [] arr_draw;
delete [] arr_draw_save;
delete [] arr_res; }
return ;
}

OpenJudge 2813 画家问题 / Poj 1681 Painter's Problem的更多相关文章

  1. POJ 1681 Painter's Problem 【高斯消元 二进制枚举】

    任意门:http://poj.org/problem?id=1681 Painter's Problem Time Limit: 1000MS   Memory Limit: 10000K Total ...

  2. poj 1681 Painter's Problem

    Painter's Problem 题意:给一个n*n(1 <= n <= 15)具有初始颜色(颜色只有yellow&white两种,即01矩阵)的square染色,每次对一个方格 ...

  3. POJ 1681 Painter's Problem(高斯消元+枚举自由变元)

    http://poj.org/problem?id=1681 题意:有一块只有黄白颜色的n*n的板子,每次刷一块格子时,上下左右都会改变颜色,求最少刷几次可以使得全部变成黄色. 思路: 这道题目也就是 ...

  4. POJ 1681 Painter's Problem (高斯消元)

    题目链接 题意:有一面墙每个格子有黄白两种颜色,刷墙每次刷一格会将上下左右中五个格子变色,求最少的刷方法使得所有的格子都变成yellow. 题解:通过打表我们可以得知4*4的一共有4个自由变元,那么我 ...

  5. POJ 1681 Painter's Problem (高斯消元 枚举自由变元求最小的步数)

    题目链接 题意: 一个n*n 的木板 ,每个格子 都 可以 染成 白色和黄色,( 一旦我们对也个格子染色 ,他的上下左右 都将改变颜色): 给定一个初始状态 , 求将 所有的 格子 染成黄色 最少需要 ...

  6. POJ 1681 Painter's Problem [高斯消元XOR]

    同上题 需要判断无解 需要求最小按几次,正确做法是枚举自由元的所有取值来遍历变量的所有取值取合法的最小值,然而听说数据太弱自由元全0就可以就水过去吧.... #include <iostream ...

  7. poj 1681 Painter&#39;s Problem(高斯消元)

    id=1681">http://poj.org/problem? id=1681 求最少经过的步数使得输入的矩阵全变为y. 思路:高斯消元求出自由变元.然后枚举自由变元,求出最优值. ...

  8. POJ 1222 POJ 1830 POJ 1681 POJ 1753 POJ 3185 高斯消元求解一类开关问题

    http://poj.org/problem?id=1222 http://poj.org/problem?id=1830 http://poj.org/problem?id=1681 http:// ...

  9. poj 1681(Gauss 消元)

    Painter's Problem Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 5875   Accepted: 2825 ...

随机推荐

  1. 2015北京网络赛 H题 Fractal 找规律

    Fractal Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://hihocoder.com/contest/acmicpc2015beijingo ...

  2. UVa 131 - The Psychic Poker Player

    题目:手里有五张牌,桌上有一堆牌(五张).你能够弃掉手中的k张牌,然后从牌堆中取最上面的k个. 比較规则例如以下:(按优先级排序) 1.straight-flush:同花顺.牌面为T(10) - A, ...

  3. Nginx动静分离经典

    Nginx:安装nginx之前需要安装pcre包和zlib以支持重写,正则以及网页压缩等等]把所需的包下载到/usr/src下[根据自己的习惯,路径可以改变]1.首先安装pcre: cd /usr/s ...

  4. Android仿腾讯应用宝 应用市场,下载界面, 有了进展button

    近期应用市场做,需要使用.下载与进度显示button,因此,要寻找其他大神做,直接用于改善.和很多无用的切出.在改进共享后. 再一次改变.当下载进度时,有进步.进度显示自己主动运行文本.并设置背景为灰 ...

  5. extremeComponents(ec)源码分析

    eXtremeComponents(简称ec)是一系列提供高级显示的开源JSP定制标签,当前的包含的组件为eXtremeTable,用于以表形式显示数据. 其本质是jsp的自定义标签,抓住这一点就抓住 ...

  6. 多线程GCD

    经常使用:规避很多线程相关的复杂的逻辑 为什么会gcd?因为pthread和nsthread要求开发人员对线程相关的知识了解深入; 手动启动线程:加锁/解锁;造成很多隐患 --> 苹果公司给出了 ...

  7. AT-FragmentPagerAdapter

    关于FragmentPagerAdapter的粗略翻译 英文版api地址:FragmentPagerAdapter(自备梯子) FragmentPagerAdapter    类概述(Class Ov ...

  8. opencv拼接相关1

    这里面都是一些比较杂的东西,没什么实际意义.主要是为了,后面能跑一个程序: Stitcher: 抠细节: http://docs.opencv.org/2.4.2/modules/stitching/ ...

  9. HeaderTemplate

    前台代码: <asp:Repeater ID="rptList" runat="server" onitemdatabound="doSomet ...

  10. ORM之PetaPoco入门(一)--Petapoco简介

    1. ORM概括 1.1. ORM简介 ORM 对象-关系映射(Object/Relation Mapping,简称ORM),是随着面向对象的软件开发方法发展而产生的.面向对象的开发方法是当今企业级应 ...