vijos1197-费解的开关【递推,枚举,位运算】

正题

题目链接:https://vijos.org/p/1197


大意

有5*5个开关,每次选择一个地方时它和它上下左右的开关都会取反,求将所有开关都变成1的最少次数。


解题思路

首先我们知道一个位置一定不会点击超过一次。这样我们就可以得出一条性质,当第一行都已经决定是否点击过后,第一行就只能由第二行点击,那么这时第二行只能点击第一行还没打开的灯的下面,这样以此类推的话第二条性质就出来了。
如果第一行决定是否点击的方案了,如果有解的话,那么只有一种点击方式。
这样的话我们就可以枚举第一行每格是否点击,然后我们就可以推出后面几行,如果有解的话那么就取最小解。


代码

#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std;
const int n=5;
int s[7],bs[7],ans,mins,t;
char a;
int main()
{scanf("%d",&t);for (int ti=1;ti<=t;ti++){for(int i=1;i<=n;i++){bs[i]=0;for(int j=1;j<=n;j++){cin>>a;a-='0';bs[i]=(bs[i]<<1)+a;//读入}}mins=2147483647;for (int i=0;i<=31;i++)//枚举{ans=0;for (int j=1;j<=n;j++)s[j]=bs[j];for (int j=0;j<=n;j++)if (i&(1<<j))//是否点击{if (j!=n-1)s[1]^=1<<(j+1);s[1]^=1<<j;if (j!=0)s[1]^=1<<(j-1);s[2]^=1<<j;ans++;}//改变和统计for (int j=2;j<=n;j++)for (int k=0;k<n;k++)if (!((s[j-1]>>k)&1))//上一行是否还有{if (k!=n-1)s[j]^=1<<(k+1);s[j]^=1<<k;if (k!=0)s[j]^=1<<(k-1);s[j+1]^=1<<k;ans++;}//改变和统计if (s[n]==31)//有解mins=min(mins,ans);//取最小答案}if (mins>6) printf("-1\n");else printf("%d\n",mins);}
}

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

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

相关文章

Linux+.NetCore+Nginx搭建集群

本篇和大家分享的是LinuxNetCoreNginx搭建负载集群&#xff0c;对于netcore2.0发布后&#xff0c;我一直在看官网的文档并学习&#xff0c;关注有哪些新增的东西&#xff0c;我&#xff0c;一个从1.0到2.0的跟随者这里只总结一句话&#xff1a;2.0版本&#xff0c;api更多&…

老师 累了,我们 泪了!

“以下文章来自一位不愿意透露姓名的同学所写&#xff1a;”呀呼 “老穆头” 没错是我们的穆老师悄悄往我们班探了探头瞧了瞧我们&#xff0c; 我们依旧对他那么热情&#xff0c;紧随其后老佟往门口一站 教室里立马严肃起来 她是我们级部出了名没人敢惹的老佟&#xff08;佟老…

汇编语言(二十)之分类统计字符个数

输入一串字符串&#xff0c;分别统计英文字符&#xff0c;数字字符和其他字符的个数 程序运行&#xff1a; 代码&#xff1a; datas segmentline_max_length db 0ffhline db 0, 100h dup(?)letter_count dw 0digit_count dw 0other_count …

POJ3263-Tallest Cow【前缀和】

正题 大意 有n头牛&#xff0c;两头牛可以相互看见仅当他们中间没有比他们高的牛&#xff0c;现在已经知道最高的牛是第p头&#xff0c;高度为h。还知道m对关系表示两头牛之间可以相互看见&#xff0c;求每头牛最高高度。 解题思路 我们先无视最高的一头牛&#xff0c;我们假…

.NET Core+Selenium+Github+Travis CI =amp;gt; SiteHistory

前言 总是三分钟热度的我折腾了一个可以每天自动截取指定网站页面并保存到Github的项目SiteHistory&#xff0c;感觉挺好(每次都这样 frameborder"0" scrolling"no" style"border-width: initial; border-style: none; width: 25px; height: 26px;&qu…

汇编语言(二十一)之数值交换与自增

输入两个数&#xff0c;如果第一个数为偶数第二个数为奇数&#xff0c;互换位置&#xff1b;如果两个数都是奇数&#xff0c;则两个数都加一 程序运行&#xff1a; 代码&#xff1a; datas segmentA dw 0 B dw 0a_string db 0ffh, 0 ,100h dup(?)b_string …

2021 程序媛跳槽记:学习计划篇(已收获字节等offer)

今天推荐的这篇文章是一位互联网程序媛写的跳槽日记。她本硕毕业于985计算机专业&#xff0c;先后就职于央企和BAT。这一篇就是她跳槽到互联网的学习笔记&#xff0c;希望能对大家有所帮助&#xff0c;感兴趣的读者也可以关注公众号&#xff0c;听听更多程序媛的故事~ 坦白说&a…

二分二题-P1678,P3902【二分,LIS】

T1:P1678 烦恼的高考志愿 评测记录:https://www.luogu.org/record/show?rid9644174 大意 有m个分数线&#xff0c;有n个估分&#xff0c;给每个估分找一个最接近的分数线&#xff0c;输出每个估分和它最接近的分数线的差之和。 解题思路 我们先将分数排序 我们可以找到一个…

Orleans的集群构建

听闻一周前,微软公布了.net core2.0,以及各种各样的其他core2.0.大家都很兴奋.微妈的诚意真是满满的.这次开源势头让我感觉到了微妈的技术实力之雄厚.我在这里祝福C#越来越好.细心的人似乎发现Orleans在github中是和net core分在一起的.Orleans的2.0何时发布呀… 现在我们面对…

汇编语言(二十二)之统计减去奇数的个数

输入一个正数&#xff0c;该数减去递增奇数&#xff08;从1开始&#xff09;直至小于等于零为止&#xff0c;计算该数减去奇数的个数 程序运行&#xff1a; 代码&#xff1a; datas segmentNUM dw 17ANS dw 0NUM_string db 0ffh, 0 ,100 dup(?)inputNUM …

卸载抖音和微博的一天……

“大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂。”抖音&#xff0c;这个APP也不知道出来多久了&#xff0c;但是印象中出来的时间不久&#xff1b;微博&#xff0c; 出来的时间要比抖音早很多&#xff0c; 记得我的第一篇微博是在2012年…

二分答案二题-P1182数列分段II,P1873砍树

T1:P1182T1:P1182数列分段SectionIISectionII评测记录&#xff1a;https://www.luogu.org/recordnew/lists?uid52918&pidP1182 大意 有n个数&#xff0c;要求分成m段使每段的和之中的最大值最小。 解题思路 二分最大值&#xff0c;然后枚举过去看至少分成几段。然后利用…

.NET Core 在程序集中集成Razor视图

前言 有时候&#xff0c;我们在开发一个程序集供其他项目引用的时候&#xff0c;可能需要对外输出一些HTML的结构数据。 还有一些情况我们可能开发的是一个中间件&#xff0c;这个中间件需要提供一些界面来对外展示数据或者是内部的一些程序的运行信息&#xff0c;这个时候我…

开学一月,可以自己玩自己做的游戏了!!!

“大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂。”《趣味小游戏》的书已经讲完了&#xff0c;国庆假期给同学们布置了小游戏项目的任务&#xff0c;开学时检查了下&#xff0c;大部分做的还是挺不错的。有的同学超常发挥想象&#xff0…

汇编语言(二十三)之求一个数的补数

给定一个数&#xff0c;求该数的补数 程序运行&#xff1a; 代码&#xff1a; datas segmentNUM DB 12H,34H,56H,78H,9AH,0BCH,23H,45HDB 67H,89H,0DEH,13H,24H,35H,46H,57HN DB $-NUMoutputNUM db "orignal data NUM$"outputNUMC d…

POJ2018-Best Cow Fences【实数二分答案】

正题 题目链接&#xff1a;http://poj.org/problem?id2018 大意 有n个数&#xff0c;一段长度不小于L的子段&#xff0c;使他们的平均值最大。 解题思路 二分答案&#xff0c;然后一遍暴力用最大子段和的方法求出是否可以。 code #include<cstdio> #include<algo…

ASP.NET Core 防止跨站请求伪造(XSRF\/CSRF)攻击

什么是反伪造攻击? 跨站点请求伪造&#xff08;也称为XSRF或CSRF&#xff0c;发音为see-surf&#xff09;是对Web托管应用程序的攻击&#xff0c;因为恶意网站可能会影响客户端浏览器和浏览器信任网站之间的交互。这种攻击是完全有可能的&#xff0c;因为Web浏览器会自动在每…

汇编语言(二十四)之输出n行星号

输入一个数n&#xff0c;输出n行星号 程序运行&#xff1a; 代码&#xff1a; datas segmentline_number_max_len db 0ffhline_number db 0, 100h dup(?)input_line_number_prompt db input line number:$output db 0dh,0…

家的味道,家的感觉!!!

“大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂。”国庆期间回了一趟家&#xff0c;上次从家里出来还是2020年正月的时候&#xff0c;因为疫情的原因&#xff0c;21年过年没有回去……早早的就买下回家的票&#xff0c;以前回家一趟&…

POJ3889-Fractal Streets【分形,递归,分治】

正题 题目链接&#xff1a;http://poj.org/problem?id3889 大意 第一级城市为图一&#xff0c;然后每次扩展一级就将原本的城市复制3份&#xff0c;一份放上面&#xff0c;一份正旋90’放左上&#xff0c;一份逆序90’放左边&#xff0c;最后将4份的头和尾连起来&#xff0c;…