ACAG 0x02-4 费解的开关

对于这道题,我们不难发现如下性质:

  1. 每个位置之多被点击一次;
  2. 点击的先后顺序不影响结果;
  3. 若确定了第$1$行,则接下来可能的点击方案就只有$1$种。具体原因是:当第$i$行某一位为$0$时,此时前$i$行均已确定,所以只能点击第$i+1$行该位置上的数,才能使第$i$行的这一位变成$1$。

    于是,我们只需要考虑第一行的点击方法。不难枚举得,共$32$种。我们可以用$0$~$31$的二进制表示点击方法。

    然后,对于每种方法,我们可以递推出接下来$2$~$5$行的点击方法,最后进行检查。如果矩阵全变为$1$,则说明该方案合法。并更新答案。

    此外,在检查的时候,只需要检查最后$1$行即可。
  1. #include<bits/stdc++.h>
  2. #define INF 0x3f3f3f3f
  3. using namespace std;
  4. int n,ans,tmp;
  5. int a[7][7],b[7][7];
  6. char s[7];
  7. void Read() {
  8. for(int i=1;i<=5;i++) {
  9. cin>>(s+1);
  10. for(int j=1;j<=5;j++) {
  11. a[i][j]=s[j]-'0';
  12. }
  13. }
  14. ans=INF;
  15. return;
  16. }
  17. void Init() {
  18. for(int i=1;i<=5;i++) {
  19. for(int j=1;j<=5;j++) {
  20. b[i][j]=a[i][j];
  21. }
  22. }
  23. tmp=0;
  24. return;
  25. }
  26. void Change(int x,int y) {
  27. b[x][y]==1?b[x][y]=0:b[x][y]=1;
  28. b[x][y-1]==1?b[x][y-1]=0:b[x][y-1]=1;
  29. b[x][y+1]==1?b[x][y+1]=0:b[x][y+1]=1;
  30. b[x-1][y]==1?b[x-1][y]=0:b[x-1][y]=1;
  31. b[x+1][y]==1?b[x+1][y]=0:b[x+1][y]=1;
  32. tmp++;
  33. return;
  34. }
  35. bool Check() {
  36. if(tmp>6) {
  37. return false;
  38. }
  39. for(int i=1;i<=5;i++) {
  40. if(b[5][i]==0) {
  41. return false;
  42. }
  43. }
  44. return true;
  45. }
  46. void DFS(int x) {
  47. if(x==6) {
  48. if(Check()) {
  49. ans=min(ans,tmp);
  50. }
  51. return;
  52. }
  53. for(int i=1;i<=5;i++) {
  54. if(b[x-1][i]==0) {
  55. Change(x,i);
  56. }
  57. }
  58. DFS(x+1);
  59. }
  60. void Solve() {
  61. for(int i=0;i<=31;i++) {
  62. Init();
  63. for(int j=0;j<=4;j++) {
  64. int x=(i>>j)&1;
  65. if(x) {
  66. Change(1,j+1);
  67. }
  68. }
  69. DFS(2);
  70. }
  71. printf("%d\n",ans==INF?-1:ans);
  72. return;
  73. }
  74. int main()
  75. {
  76. scanf("%d",&n);
  77. for(int i=1;i<=n;i++) {
  78. Read();
  79. Solve();
  80. }
  81. return 0;
  82. }

ACAG 0x02-4 费解的开关的更多相关文章

  1. AcWing 95 费解的开关

    目录 前言 题目链接 思路 代码 前言 博客咕咕咕了好久了,是时候写一下了 题目链接 AcWing 95 费解的开关 思路 首先可以看出 1.每一个位置顶多只会操作一次.因为如果操作两次的话,相当于不 ...

  2. TyvjP1266 费解的开关

    P1266 费解的开关 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述     你玩过“拉灯”游戏吗?25盏灯排成一个5x5的方形.每一个灯都有一个开关,游戏 ...

  3. TVYJ1266:费解的开关

    我对状态空间的理解:https://www.cnblogs.com/AKMer/p/9622590.html 题目传送门:http://www.joyoi.cn/problem/tyvj-1266 这 ...

  4. ACWING 95 费解的开关 解题记录

    你玩过“拉灯”游戏吗?25盏灯排成一个5x5的方形.每一个灯都有一个开关,游戏者可以改变它的状态.每一步,游戏者可以改变某一个灯的状态.游戏者改变一个灯的状态会产生连锁反应:和这个灯上下左右相邻的灯也 ...

  5. 【ACwing 95】费解的开关——枚举 + 搜索

    (题面来自ACwing) 你玩过"拉灯"游戏吗?25盏灯排成一个5x5的方形.每一个灯都有一个开关,游戏者可以改变它的状态.每一步,游戏者可以改变某一个灯的状态.游戏者改变一个灯的 ...

  6. ACWing95. 费解的开关

    题解 这道题目有三个状态条件值得考虑: 每一个开关被按0次或者1次才有意义,如果超过1次,那么等同于按0或1次. 最终的结果与按的顺序无关 因为2,所以可以人为地规定比较合理的顺序. 现在以每一行为顺 ...

  7. TYVJ1266 费解的开关

    恩,这题...... 看看题面想到了啥?炮兵阵地! 再仔细一思考:炮兵阵地是求放置最多,而这个显然可以递推得出. 由于每个格子至多点一次,那么我们发现: 在第一行点击状态确定的情况下,后面每个格子的点 ...

  8. CH0201 费解的开关 枚举

    正解:枚举 解题报告: 入门傻逼题,思维难度不高代码量极小,非常适合上手 然后傻逼的我第二次看这道题的时候依然没想到解法:D 没有办法,就想着写个笔记好歹记录一下以后多复习几次就记着了趴qwq 就是, ...

  9. tyvj 1266 费解的开关

    传送门 解题思路 枚举第一行的状态,判断后面可不可行. 代码 #include<iostream> #include<cstdio> #include<cstring&g ...

随机推荐

  1. 一次升级jar包遇到的空指针异常

    今天自己在升级公司的一个jar后,一直报空指针异常.代码如下 package com.zhuanche.http; import com.alibaba.fastjson.JSON; import c ...

  2. [Python] 项目的配置覆盖与合并

    参考来源: https://www.liaoxuefeng.com/wiki/1016959663602400/1018490750237280 代码稍微修改了一下 import os import ...

  3. vs2015下C4819该文件包含不能在当前代码页(936)中表示的字符问题解决

    今天编译IfcOpenshell出现很多warning如下: C4819 该文件包含不能在当前代码页(936)中表示的字符.请将该文件保存为 Unicode 格式以防止数据丢失 解决方案: 文件——& ...

  4. scrollview的优化

    针对一次加载很多格子的scrollview的优化,第一次只加载可视区域的格子,其他的用空物体占位,在每次滑动时检测需要实例化的格子,通过对象池重用第一次的格子.可以根据每行格子的数量只检测每行的第一个 ...

  5. 64位linux安装了32位jdk8报错怎么办-bash:/usr/local/jdk1.8/jdk1.8.0_181/bin/java:/lib/ld-linux.so.2:badELFinterpreter:Nosuch

    -bash:/usr/local/jdk1.8/jdk1.8.0_181/bin/java:/lib/ld-linux.so.2:badELFinterpreter:Nosuch https://bl ...

  6. Java程序员经典面试题+答案(全)

    这套面试题主要目的是帮助那些还没有java软件开发实际工作经验,而正在努力寻找java软件开发工作的朋友在笔试时更好地赢得笔试和面试. 关注公众号[Java典籍]免费赠送一套Java入门视频教程一套! ...

  7. [转帖]50 亿美元!微软签下毕马威!JEDI 100 亿美元订单之后又一大单!

    50 亿美元!微软签下毕马威!JEDI 100 亿美元订单之后又一大单! https://mp.weixin.qq.com/s/K0SrFNSVK5aOu6TIzhN92Q 前段时间,微软击败亚马逊, ...

  8. Go操作ini文件

    除了采用json,yaml等格式之外,常用的配置文件还有ini格式的. cfg, err := ini.Load(fyPath + "\\ServerSystem.ini") // ...

  9. Codeforces Round #596 (Div. 1, based on Technocup 2020 Elimination Round 2)

    (第一把div1心态崩了,给大家表演了一把上蓝) (看来以后div1需要先读前三题,如果没把握切掉还是不要交了……) A: 题意是求最少用几个形如$2^{t}+p$的数拼出n,给定n和p.$n\leq ...

  10. python 字符串替换功能 string.replace()可以用正则表达式,更优雅

    说起来不怕人笑话,我今天才发现,python 中的字符串替换操作,也就是 string.replace() 是可以用正则表达式的. 之前,我的代码写法如下,粗笨: 自从发现了正则表达式也生效后,代码变 ...