当前位置: 首页 > wzjs >正文

网站建设网站推广热搜榜上2023年热门话题

网站建设网站推广,热搜榜上2023年热门话题,科学家做实验的网站,外贸网站收到询盘项目场景: 开关问题,思维题,二进制枚举思路。 问题描述 “飞行员兄弟”这个游戏,需要玩家顺利的打开一个拥有 16 个把手的冰箱。 已知每个把手可以处于以下两种状态之一:打开或关闭。 只有当所有把手都打开时&…

项目场景:

开关问题,思维题,二进制枚举思路。


问题描述

“飞行员兄弟”这个游戏,需要玩家顺利的打开一个拥有 16 个把手的冰箱。

已知每个把手可以处于以下两种状态之一:打开或关闭。

只有当所有把手都打开时,冰箱才会打开。

把手可以表示为一个 4×4 的矩阵,您可以改变任何一个位置[i,j] 上把手的状态。

但是,这也会使得第 i 行和第 j列上的所有把手的状态也随着改变。

请你求出打开冰箱所需的切换把手的次数最小值是多少。

输入格式

输入一共包含四行,每行包含四个把手的初始状态。

符号 + 表示把手处于闭合状态,而符号 - 表示把手处于打开状态。

至少一个手柄的初始状态是关闭的。

输出格式

第一行输出一个整数 N,表示所需的最小切换把手次数。

接下来 N 行描述切换顺序,每行输出两个整数,代表被切换状态的把手的行号和列号,数字之间用空格隔开。

注意:如果存在多种打开冰箱的方式,则按照优先级整体从上到下,同行从左到右打开。

数据范围

1≤i,j≤4

输入样例:

-+--
----
----
-+--

输出样例:

6
1 1
1 3
1 4
4 1
4 3
4 4

原因分析:

因为每一个位置的开关改变会影响同一行和同一列的冰箱状态,不好用递推的思路来确定任意一个冰箱的状态,因为数据范围比较小,每个开关有开和关两个状态,16个数据,共有2^16个方案,考虑用二进制的方法对每种开关的状态进行枚举,再根据每次枚举的结果进行操作,改变冰箱的状态,然后判断每种枚举方案下是否能使得冰箱处于全开的状态,最后取所有方案种,最小步数的方案。

注意,这里按照字典序的方式进行输出方案,在枚举方案时只要按照从小到大的顺序进行枚举,最终得到的方案就是按照字典序方案输出的结果。


实现代码:

#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<vector>
#define x first
#define y second
using namespace std;
typedef pair<int,int> PII;
const int N = 5;
char g[N][N],backup[N][N];int get(int x,int y){return 4*x+y;
}
void  turn_one(int x,int y){if(g[x][y]=='+') g[x][y] = '-';else g[x][y] = '+';
}
void turn_all(int x,int y){for(int i=0;i<4;i++){turn_one(x,i);turn_one(i,y);}turn_one(x,y);
}
int main(){//读入冰箱的状态 4x4矩阵for(int i=0;i<4;i++)for(int j=0;j<4;j++)cin>>g[i][j];vector<PII> res;//定义最终输出的方案//枚举所有可能的方案 开关一共有2^16种情况for(int op=0;op<1<<16;op++){memcpy(backup,g,sizeof(g));//进行备份vector<PII> temp;//根据每次枚举的开关矩阵的状态对冰箱状态进行操作for(int i=0;i<4;i++)for(int j=0;j<4;j++){//16位二进制的数 每个数有两种方案 这里的作用是求16位上对应位是否有数 如果有数的话就表示方案存在 进行操作if(op>>get(i,j)&1){//改变开关状态turn_all(i,j);//存入方案temp.push_back({i,j});}}//判断bool has_closed = false;for(int i =0;i<4;i++)for(int j=0;j<4;j++){if(g[i][j]=='+'){has_closed = true;break;}}if(!has_closed){if(res.empty()||res.size()>temp.size()) res = temp;}memcpy(g,backup,sizeof(g));//还原 使得下一次枚举方案时初始的冰箱矩阵为开始所给的情况}cout<<res.size()<<endl;for(auto m:res){cout<<m.x+1<<" "<<m.y+1<<endl;}return 0;}

http://www.dtcms.com/wzjs/517551.html

相关文章:

  • php 禁止电脑访问网站百度热搜榜排名今日第一
  • wordpress 教材主题泽成杭州seo网站推广排名
  • 新疆网站备案怎么办理电商平台如何推广运营
  • 做网站建设还有钱赚吗上海网站seo诊断
  • 网站抄袭博客程序seo
  • 网站建设中html如何免费推广自己的产品
  • 英文书 影印版 网站开发站长之家工具高清
  • 网站建设 国外seo站长网怎么下载
  • 哪个网站教人做美食外贸网站平台都有哪些 免费的
  • 外贸网站做哪些语言重庆小潘seo
  • 做企业网站支付功能长沙哪家网络公司做网站好
  • 网站建设合作品牌整站优化提升排名
  • 创意经济型网站建设杭州百度百家号seo优化排名
  • 网站官网认证怎么做的关键词生成器在线
  • 丰台网站建设公司石家庄百度快照优化排名
  • 南昌做网站的公司网站服务器地址查询
  • 雄安邯郸网站制作多少钱seo如何优化
  • 网站系统怎么做前端seo优化
  • 网站建设 个人模板下载seo模拟点击有用吗
  • 如何把动态图发网站做头像百度seo霸屏软件
  • 聊城房地产网站建设怎么做网站免费的
  • 网站建设制作设计公司佛山软件开发公司经营范围
  • 网站开发和网页设计的区别四川seo整站优化吧
  • 莱芜话题最新消息seo兼职工资一般多少
  • 网站制作添加视频国内重大新闻10条
  • 不备案的网站能打开吗优化关键词的方法包括
  • 国外优秀app设计网站应用关键词优化
  • dwcc2017怎么做网站武汉seo楚天
  • 生物科技企业网站做的比较好的源码网
  • 系统网站建设ppt模板关键词排名查询工具免费