实验四:搜索
实验四:搜索
1.填格子
题目描述
有一个由数字 0、1 组成的方阵中,存在一任意形状的封闭区域,封闭区域由数字1 包围构成,每个节点只能走上下左右 4 个方向。现要求把封闭区域内的所有空间都填写成2
输入要求
每组测试数据第一行一个整数 n(1≤n≤30)
接下来 n 行,由 0 和 1 组成的 n×n 的方阵。
封闭区域内至少有一个0 。
输出要求
已经填好数字 2 的完整方阵。
注意矩阵的每个数字后面都有一个空格
输入样例
6
0 0 0 0 0 0
0 0 1 1 1 1
0 1 1 0 0 1
1 1 0 0 0 1
1 0 0 0 0 1
1 1 1 1 1 1
输出样例
0 0 0 0 0 0
0 0 1 1 1 1
0 1 1 2 2 1
1 1 2 2 2 1
1 2 2 2 2 1
1 1 1 1 1 1
#include <iostream>
#include <queue>
using namespace std;queue<int>x;//初始化队列x来存储横坐标
queue<int>y;//初始化队列y来存储纵坐标int matrix[31][31];
int visited[31][31]={0};//visited用来记录元素是否被访问过int delta_x[4]={0,-1,0,1};//delta_x和delta_y用来进行广搜,来搜索对应元素的上下左右
int delta_y[4]={1,0,-1,0};int main()
{int N;cin>>N;for(int i=1;i<=N;i++){//从数组的索引1位置开始输入,外圈补一圈0for(int j=1;j<=N;j++){cin>>matrix[i][j];}}x.push(0);//将(0,0)坐标入队列y.push(0);visited[0][0]=1;int x1,y1;while(!x.empty()){for(int i=0;i<4;i++){//遍历对应元素的上下左右位置x1 = x.front()+delta_x[i];y1 = y.front()+delta_y[i];//如果满足没有越界且是0元素且没有被访问过if(x1>=0 && x1<=N+1 && y1>=0 && y1<=N+1 && matrix[x1][y1]==0 && visited[x1][y1]==0){x.push(x1);//则将对应的元素入队y.push(y1);visited[x1][y1]=1;} }x.pop();y.pop();}for(int p=1;p<=N;p++) {for(int q=1;q<=N;q++) {if(visited[p][q]==0 && matrix[p][q]==0){//如果元素没有被访问过,且为0元素cout<<2<<' '; }else{cout<<matrix[p][q]<<' '; } }cout<<endl;}return 0;
}
2.N皇后
题目描述
N皇后的排列,每行一个不冲突;N<=13。
输入要求
一个数字N (6 <= N <= 13) 表示棋盘是N x N大小的。
输出要求
前三行为前三个解,每个解的两个数字之间用一个空格隔开。第四行只有一个数字,表示解的总数。
解的输出顺序为从上到下从左到右,小的优先输出
输入样例
6
输出样例
2 4 6 1 3 5
3 6 2 5 1 4
4 1 5 2 6 3
4
#include <iostream>
#include <cmath>
using namespace std;
//用result来保存结果,result[i]=p表示棋子放在第i行第p列
int result[15];
//定义一个函数用来判断棋子放在当前行第p列是否合法
int is_place(int p)
{for(int i=1;i<p;i++){//对于前面p-1行来说if((result[i]==result[p]) || (abs(result[i]-result[p])==abs(i-p))){//不合法情况:在同一列或者在斜线上return 0;}}return 1;
}
// 定义函数求解N皇后问题
void Queen(int n)
{int p=1,ans=0,count=1;result[p]=1;//初始化:从第一行第一列开始放while(p>0){//对于第p行来说if(p<=n && result[p]<=n){//如果行列都没有超出矩阵范围if(is_place(p)==0){//当前列不合法result[p]=result[p]+1;//放到下一个位置}else{//当前列合法p=p+1;//到下一列去result[p]=1;//下一列从1开始}}else{//如果行列超出了索引范围,回溯if(p>n){//得到一个正确答案ans=ans+1;//正确答案数目加1if(count<=3){for(int j=1;j<n;j++){//输出一条正确答案cout<<result[j]<<" ";}cout<<result[n];cout<<endl;count++;}}p=p-1;//回到上一行result[p]=result[p]+1;//上一行的棋子往右走}}cout<<ans<<endl;
}
int main()
{int N;cin>>N;Queen(N);return 0;
}
3.再填格子
题目描述
有一个由数字 0、1 组成的方阵中,存在一任意形状的封闭区域,封闭区域由数字1 包围构成,每个节点只能走上下左右 4 个方向。现要求只把**【最大封闭区域】**内的空间填写成2 。
例如: 6×6 的方阵:
6
0 1 0 0 0 0
1 0 1 1 1 1
0 1 1 0 0 1
1 1 0 0 0 1
1 0 0 0 0 1
1 1 1 1 1 1
填写后如下:
0 1 0 0 0 0
1 0 1 1 1 1
0 1 1 2 2 1
1 1 2 2 2 1
1 2 2 2 2 1
1 1 1 1 1 1
输入要求
每组测试数据第一行一个整数 n(1≤n≤30)
接下来 n 行,由 0 和 1 组成的 n×n 的方阵。
封闭区域内至少有一个0,测试数据保证最大区域只有一个。
输出要求
已经填好数字 2 的完整方阵。(每个数字后面有一个空格!)
输入样例
6
0 1 0 0 0 0
1 0 1 1 1 1
0 1 1 0 0 1
1 1 0 0 0 1
1 0 0 0 0 1
1 1 1 1 1 1
输出样例
0 1 0 0 0 0
1 0 1 1 1 1
0 1 1 2 2 1
1 1 2 2 2 1
1 2 2 2 2 1
1 1 1 1 1 1
#include<iostream>
#include<cstring>using namespace std;
int a[40][40];
int n;
int dir[4][2] = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}}; // 右 左 下 上
int cnt = 0; // 某一个封闭区域的大小
int maxn = 0; // 最大封闭区域大小
int id = 3; // 染色区域的编号
int max_id = id;
void dfs(int x, int y)
{if(x<0 || x>n+1 || y<0 || y>n+1 || a[x][y]!=0) //禁止染色的判断 x<0 || x>n+1 || y<0 || y>n+1为矩阵4个边return ;a[x][y] = id; //染色cnt++;for(int i=0; i<4; i++){dfs(x+dir[i][0], y+dir[i][1]);}
}
int main()
{cin >> n;memset(a, 0, sizeof(a)); int i;// 输入数据 for( i=1; i<=n; i++)for(int j=1; j<=n; j++){int k;cin >> k;a[i][j] = k;}//将边缘的0和其连接块都染色dfs(0, 0);id++;for( i=2; i<n; i++)for(int j=2; j<n; j++){cnt = 0;// 搜索每一个元素,找到最大封闭区域 dfs(i, j);//cout << cnt;if(cnt > maxn){maxn = cnt;max_id = id;}id++;}
// 输出
for( i=1; i<=n; i++)
{for(int j=1; j<=n; j++){if(a[i][j] == 1)cout << a[i][j] << " ";else if(a[i][j] != max_id)cout << '0' << " ";else cout << '2' << " ";} cout << endl;}return 0;
}
4.地图着色
题目描述
地图着色问题:如果把每一个区域收缩为一个顶点,把相邻两个区域用一条边相连接,就可以把一个区域图抽象为一个平面图。用m种颜色为图中的每个顶点着色,要求每个顶点着一种颜色,并使相邻两顶点之间有着不同的颜色。运用回溯法解决该问题。
输入要求
顶点数 颜色数
邻接矩阵
输出要求
着色方案
输入样例
输出样例
#include<iostream>
#include<stdio.h>
using namespace std;
int c[100][100]; //邻接矩阵
int color[100]; //记录每个顶点的颜色
int count,m,n; //count记录方案数 n个顶点 m种颜色
int Check(int k) //检查第i个顶点的颜色是否满足条件
{for(int i=1;i<=k;i++){if(c[k][i]==1&&color[i]==color[k]) //k与i之间相连并且i顶点的颜色与k顶点的颜色相同return 0;}return 1;
}
void GraphColor(int step)
{if(step==n+1) //表示前面所有的顶点颜色都已经填完{for(int i=1;i<=n;i++)printf("%d ",color[i]);count++;printf("\n");return ;}else{for(int i=1;i<=m;i++){color[step]=i; //首先将这个顶点颜色换为iif(Check(step)==1) //检查是否符合条件{GraphColor(step+1); //符合条件则走下一步}color[step]=0; //回溯 置为0}}
}
int main(void)
{printf("请输入顶点数:");scanf("%d",&n);printf("\n");printf("请输入颜色数:");scanf("%d",&m);printf("\n");printf("请输入邻接矩阵:\n");for(int i=1;i<=n;i++)for(int j=1;j<=n;j++){cin>>c[i][j];}printf("\n方案如下:\n");GraphColor(1);printf("\n");printf("%d",count);return 0;
}
相关文章:
实验四:搜索
实验四:搜索 1.填格子 题目描述 有一个由数字 0、1 组成的方阵中,存在一任意形状的封闭区域,封闭区域由数字1 包围构成,每个节点只能走上下左右 4 个方向。现要求把封闭区域内的所有空间都填写成2 输入要求 每组测试数据第一…...
本地开发vue项目联调遇到访问接口跨域问题
本地开发vue项目联调遇到访问接口跨域问题 修改本地的localhost 一:按winr打开运行窗口,输入drivers ,然后回车 二:打开etc文件夹,然后用记事本的方式打开里面的hosts文件, 三:这时我们就可…...
Vue键盘事件的使用
前言 在vue中,我们经常会用到键盘事件,不管是我们按下某个键,其实都是一次键盘事件的调用,下面就介绍下Vue中的键盘事件 先写一段代码,这里我选择的键盘事件是keyup,当然用keydown也是没问题的 问题来了,…...
抓包工具fiddler详细使用教程
各位做测试的同学想必对抓包工具fiddler并不陌生,但是很多同学可能没有总结过它的用法,下面我总结了fiddler一些常用的用法。 Web端抓包配置 打开Fiddler,Tools -> Fiddler Options -> HTTPS 配置完后记得要重启Fiddler 选中Decrpt …...
raspberry Pi 连接蓝牙(小爱同学)
参数valueraspberry pi MOdel4B,4Gbbluetooth MOdel小爱同学writeTime2023年 2月11日 下午13:14分raspberry System ModelLinux raspberrypi 5.15.61-v8 #1579 SMP PREEMPT Fri Aug 26 11:16:44 BST 2022 aarch64 GNU/Linux 连接蓝牙 请在小爱同学app上…...
解决launch:program .exe does not exist
二. 程序的运行和调试 1.launch.json 复制下列代码至launch.json,并根据指导做出相对/绝对路径修改 用 IntelliSense 了解相关属性。 {// 使用 IntelliSense 了解相关属性。 // 悬停以查看现有属性的描述。// 欲了解更多信息,请访问: https://go.micros…...
ETL --事实表
每一个事实表通过表的粒度来定义。事实表的粒度是事件度量的定义。我们必须至始至终按照度量如何在 现实世界中理解来规定事实表的粒度。 所有的事实表包含了一组关联到维表的外键,而这些维表提供了事实表度量的上下文。大多数的事实表还 包括了一个或者多个数值型…...
手工数据采集耗时耗力?Smartbi数据填报实现数据收集分析自动化
企业在日常经营管理过程中,往往需要收集很多内外部的信息,清洗整理后再进行存储、分析、呈现、决策支持等各种作业,如何高效收集结构化数据是企业管理者经常要面对的问题。传统手工的数据采集方式不仅耗费了大量人力时间成本,还容…...
应用实战|微信小程序开发示例--多人聊天互动空间
“超能力”数据库~拿来即用,应用开发人员再也不用为撰写API而发愁。MemFire Cloud 为开发者提供了简单易用的云数据库(表编辑器、自动生成API、SQL编辑器、备份恢复、托管运维),很大地降低开发者的使用门槛。 本示例是…...
css:使用filter和backdrop-filter实现高斯模糊效果
背景 今天接到一个需求是,使用高斯模糊的效果对一个页面进行模糊处理,正好借这个机会来整理一下 css3 中高斯模糊的两个 API API介绍 filter 说明: 该 API 是一个过滤器,不仅能实现高斯模糊,还有很多比如颜色偏移、…...
科技大势怎么看 2023怎么干?
2023年,科技的走向依旧是世界各国的关注重点,各国在纷纷设立自己的科技战略目标外,还在潜心研究不同技术领域的科技趋势,试图通过科技占据国际竞争的制高点。 随着我国深入实施创新驱动发展战略,推动产业结构优化升级&…...
盘点曾经很火但消失了的8个软件
目录 1、飞信 3、暴风影音 4、千千静听 5、虾米音乐 6、快车下载 7、人人网 8、QQ农场 今天小编给大家分享曾经很火但消失了的8个软件,你都用过吗? 1、飞信 飞信是中国移动通信集团公司推出的一款短信、语音、视频通信应用程序。它于2007年推出&a…...
安卓 Frament + ViewPager使用示例
1. 组成架构 整个架构被包在一个外部Fragment之中,也可以放在一个Activity之中,随意。外部的fragment包含了两个组件,即途中的ViewPager和TabLayoutViewPager要套上一个FragmentStatePagerAdapter ,适配器负责new出一个个fragment…...
【银行测试】必看的四类题型:这可是最经典的一套题目了
目录:导读 一、根据题目要求写出具体LINUX操作命令 二、JMETER题目 三、根据题目要求写出具体SQL语句 四、测试案例设计题 金三银四面试面对大厂面试官提问,如何回答:花3天背完这100道软件测试面试题!银行测试的offer还不是手…...
跨源资源共享(CORS)-亲测理解,以及对http的状态,参数的理解和使用,对预检请求的触发和解决
跨源资源共享(CORS)-亲测理解,以及对http的状态,参数的理解和使用 跨源资源共享(CORS,或通俗地译为跨域资源共享)是一种基于HTTP 头的机制,该机制通过允许服务器标示除了它自己以外的…...
学生使用的台灯该怎么选择?2023适合学生房间的灯推荐
随着社会的进步发展,我们的生活水平越来越高,很多家庭的孩子都开始使用台灯这种家居产品,对于学习任务繁重的他们来说,台灯确实可以起到保护眼睛、提高学习专注度的作用。那么不知道朋友们是否了解过,台灯该怎么选择呢…...
23种设计模式-桥接模式(安卓应用场景介绍)
概念 桥接模式是一种结构型设计模式,它通过将抽象与其实现分离来解耦。它使用接口(抽象类)作为桥梁,将一个抽象类与其实现类的代码分别独立开来,从而使它们可以各自独立地变化。桥接模式的核心思想是“组合优于继承”…...
2021牛客OI赛前集训营-提高组(第四场) T3快速访问
2021牛客OI赛前集训营-提高组(第四场) 题目大意 有一棵n1n1n1个节点的树,根节点为0。给你一个kkk,定义集合Si{j∈Z∣max(1,i−k)≤j<i}∪{0}S_i\{j\in Z|\max(1,i-k)\leq j<i\}\cup\{0\}Si{j∈Z∣max(1,i−k)≤j<i…...
【大数据是什么】
大数据是什么大数据是做什么的?大数据主要有哪些职位 ?大数据运维工程师数据仓库开发工程师ETL工程师大数据开发工程师BI工程师算法工程师大数据平台开发工程师大数据架构师讲述一下自己的大数据学习之路大数据是做什么的? 2014年,…...
大数据 | centos7图形界面无法执行yum命令
大家好,今天是三八女神节了! 你知道吗?世界上第一位电脑程序设计师是名女性,Ada Lovelace (1815-1852)。 她是一位英国数学家兼作家,第一位主张计算机不只可以用来算数的人,也发表了第一段分析机用的演算…...
三维人脸实践:基于Face3D的渲染、生成与重构 <一>
face3d: Python tools for processing 3D face git code: https://github.com/yfeng95/face3d paper list: PaperWithCode 该方法广泛用于基于三维人脸关键点的人脸生成、属性检测(如位姿、深度、PNCC等),能够快速实现人脸建模与渲染。推荐…...
Javascript 设计模式
设计模式的五大设计原则(SOLID)单一职责:一个程序只需要做好一件事。如果功能过于复杂就拆分开,保证每个部分的独立开放封闭原则:对扩展开放,对修改封闭。增加需求时,扩展新代码,而不是修改源代码。这是软件设计的终极…...
JAVA-文档工具screw-gui
前言 为什么萌生了写文档工具得想法,因为在项目开发得过程中,经常需要补充一些文档,比如数据库文档、详细设计文档等等,文档与项目相绑定,在项目需求新增或变更时,文档也需要反反复复得修改。 1. 数据库…...
开源鸿蒙南向嵌入学习笔记——NAPI框架学习(一)
开源鸿蒙南向嵌入学习笔记——NAPI框架学习(一) 前言——系列介绍 本系列文章主要是记录笔者在鸿蒙南向的学习与工作中的知识点笔记记录,其中不止会针对鸿蒙中的学习问题进行思考与记录,也会对涉及到的一些嵌入式等其他领域知识&…...
Spring - Spring框架概述面试题总结
文章目录01. 什么是Spring?02. Spring框架的设计目标,设计理念,和核心是什么?03. Spring的优点是什么?04. Spring框架中都用到了哪些设计模式?05. Spring有哪些应用场景?06. Spring由哪些模块组成…...
学习python好就业么
Python的普及与数据挖掘、人工智能和数值计算等领域的蓬勃发展相关,但同时也与普遍编程需求的增加有关。 Python作为人工智能的头号语言,一方面会吸引大量计划从事人工智能的人来学习,另一方面自然也带动了网络上对这门“新语言”的关注和讨…...
瑞幸咖啡的最终目标并不是做国内市场大哥
出品 | 何玺 排版 | 叶媛 日前,瑞幸咖啡发布2022年第四季度及全年财报。数据显示,在刚刚过去的2022年,瑞幸咖啡首次实现了营收超百亿,门店规模也超越老对手星巴克,成为了国内第一连锁咖啡品牌。 那么,瑞幸…...
GPT 模型介绍 | GPT3 / GPT3.5 + Flask | Github源码链接
1. 模型介绍 Chatgpt 使用与 InstructGPT相同的方法,使用来自人类反馈的强化学习 (RLHF) 来训练该模型,但数据收集设置略有不同。我们使用监督微调训练了一个初始模型:人类 AI 训练员提供对话,他们在对话中扮演双方——用户和 AI…...
蓝桥杯入门即劝退(二十六)组合问题(回溯算法)
-----持续更新Spring入门系列文章----- 如果你也喜欢Java和算法,欢迎订阅专栏共同学习交流! 你的点赞、关注、评论、是我创作的动力! -------希望我的文章对你有所帮助-------- 专栏:蓝桥杯系列 一、题目描述 给定两个整数 n …...
现代卷积神经网络(ResNet)
专栏:神经网络复现目录 本章介绍的是现代神经网络的结构和复现,包括深度卷积神经网络(AlexNet),VGG,NiN,GoogleNet,残差网络(ResNet),稠密连接网络…...
单县网站建设/seo技术培训宁波
很多人选择编程行业是冲着它的高薪来的,在所有行业中程序员的薪资还是相当具有吸引力的,至少工作几年后绝大部分人的薪资水平能超过国家统计局统计出来的平均工资,那么你会让你的孩子当程序员吗? 看看各位网友们的回答࿱…...
jquery做网站浏览量/统计工具
情况①: for (int i 0; i < 100; i) {j 1 j; } System.out.println(j); 结果是 0 !! 这是由于在进行后自增/自减(j-- j)操作的时候,先开辟一块新的内存空间来保存运算之间的 j 值,然后…...
网页制作工具有什么/百度视频排名优化
C一、选择题1、 若已经定义“struct stu {int a, b;} student;”,则下列输入语句中正确的是D)scanf(“%d”,&student.a);2、 若已有以下结构体定义,则值为2的表达式是A)c[0].y;struct cmplx{int x;int y;}c[]{1,2,…...
网站seo诊断方案/品牌网络营销推广方案策划
目录 原理框图 Vivado中添加&配置Zynq UltraScale MPSoc IP UART设置(仅用于调试,非必需) MIO、EMIO设置 DDR配置 执行Generate Output Products 执行Create HDL Wrapper 执行File -> Export ->Export Hardware 执行Launch S…...
wordpress主题常规选项修改不/网络运营与推广
MCP79412实时时钟驱动仿真 1、MCP79412介绍 MCP79412 通用 I2C™ 兼容实时时钟 / 日历(RTCC)与非易失性存储器和通常在高价设备中常见的高级功能高度集成。 这些功能包括用于备用电源的电池切换电路、用于记录电源故障的时间戳和用于准确性的数字微调。 使用低成本的 32.76…...
有没有卖设计的网站/长春网站建设推广
第十一课 最陡下降法解方程 梯度法 前面描述的几种方法有时被称为“平稳”方法,因为它们没有根据试解中误差的值来修改收敛过程。 相比之下,在梯度法中,误差被重复评估,并生成新的试解。在我们的第一个例子中,我们将…...