CODE[VS] 3411 洪水

题目描述 Description

小浣熊松松和朋友到野外露营,没想到遇上了π年一次的大洪水,好在松松是一只爱观察的小浣熊,他发现露营地的地形和洪水有如下性质:

①露营地可以被看做是一个N*M的矩形方阵,其中左上角坐标为(1,1),右下角坐标为(n,m),每个格子(i,j)都有一个高度h(i,j)。

②洪水送(r,c)开始,如果一个格子被洪水淹没,那这个格子四周比它低(或相同)的格子也会被淹没。

现在松松想请你帮忙算算,有多少个格子不会被淹没,便于他和朋友逃脱。

【原有误数据已删除】

 

输入描述 Input Description

第一行包含两个整数n,m,表示矩形方阵右下角坐标。

以下n行,每行m个数,第i行第j个数表示格子(i,j)的高度。

最后一行包含两个整数r,c,表示最初被洪水淹没的格子。

输出描述 Output Description

输出仅一行,为永远不会被淹没的格子的数量。

 

样例输入 Sample Input

3 3

1 2 3

2 3 4

3 4 5

2 2

样例输出 Sample Output

5

 

数据范围及提示 Data Size & Hint

对于90%的数据,保证随机生成。

对于100%的数据,1<=N,M<=1000。

 

标签是bfs,

我只会用dfs。

 

下面是dfs爆搜。

 

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;int n,m,h[1002][1002],a,b,ans=1;
int xx[5]={-1,1,0,0},yy[5]={0,0,1,-1};
bool w[1002][1002],vis[1002][1002];void dfs(int x,int y)
{vis[x][y]=1;for(int i=0;i<4;++i){int dx=x+xx[i],dy=y+yy[i];if(dx<1||dx>n||dy<1||dy>m||w[dx][dy]==1||vis[dx][dy]==1) continue;if(h[dx][dy]<=h[x][y]){w[dx][dy]=1;ans++;}}for(int i=1;i<=n;++i)for(int j=1;j<=m;++j)if(w[i][j]==1&&!vis[i][j]) dfs(i,j);
}int main()
{scanf("%d%d",&n,&m);for(int i=1;i<=n;++i)for(int j=1;j<=m;++j)scanf("%d",&h[i][j]);scanf("%d%d",&a,&b);w[a][b]=1;dfs(a,b);printf("%d",n*m-ans);
}
DFS75

 

 

这个也是dfs,还是很慢,不过能过这道题,

对比一下思路吧。

 

#include<cstdio>
#include<iostream>
using namespace std;int next[4][2]= {{0,1},{0,-1},{1,0},{-1,0}};
int mp[1000][1000];
int a[1000][1000];
int n,m,sum=0;void dfs(int x,int y)
{sum++;int t;t=mp[x][y];int i,j;for(i=0; i<4; i++){int xx=x+next[i][0];int yy=y+next[i][1];if(xx<1||yy<1||xx>n||yy>m)continue ;if(mp[xx][yy]<=t&&a[xx][yy]==0){a[xx][yy]=1;dfs(xx,yy);}}
}int main()
{int i,j;cin>>n>>m;for(i=1; i<=n; i++)for(j=1; j<=m; j++)cin>>mp[i][j];int x;int y;cin>>x>>y;a[x][y]=1;dfs(x,y);cout<<n*m-sum<<endl;return 0;
}
dfs AC

 

 

 

有人说这是个bfs的板子。

hh,反正我不会。

狗子zxl又在外面发火了。。。

 

另附一份bfsAC代码。

自行理解。

 

#include<iostream>
#include<queue>
using namespace std;struct point
{int x,y;
};int dir[4][2]= {{-1,0},{1,0},{0,-1},{0,1}};
int lock[1001][1001] = {0};
int a[1001][1001];
int n, m, sum=0;void BFS(int x, int y)
{queue <point> q;point now,  next;now.x = x,   now.y = y;q.push(now);lock[now.x][now.y] = -1;while(!q.empty()){now = q.front();for(int i=0; i<4; i++){next.x = now.x + dir[i][0];next.y = now.y + dir[i][1];if(next.x<=0||next.y<=0||next.x>n||next.y>m) //判断是否越界continue;if((a[next.x][next.y]<=a[now.x][now.y])&&lock[next.x][next.y]!=-1)//如果洪水可以淹没,且点没有访问过
            {q.push(next);  //该点入栈lock[next.x][next.y] = -1;}}q.pop();sum++;}
}int main()
{int p1, p2;cin>>n>>m;for(int i=1; i<=n; i++){for(int j=1; j<=m; j++)cin>>a[i][j];}cin>>p1>>p2;BFS(p1,p2);cout<<n*m-sum<<endl;return 0;
}
bfs

 

 

 

 

 

 

转载于:https://www.cnblogs.com/Mary-Sue/p/9163418.html

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

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

相关文章

JavaScript --- 取得鼠标事件的坐标

说明: clientX和clientY属性&#xff1a;事件发生时,鼠标指针在视口中的水平和垂直坐标。pageX和pageY属性&#xff1a;鼠标光标在页面中的位置。screenX和screenY属性&#xff1a;鼠标事件发生时&#xff0c;鼠标指针相对于整个屏幕的坐标信息。IE8及更早的版本不支持事件对象…

JavaScript语义基础

变量&#xff08;Variables&#xff09; Variables是你存储数据的容器。声明一个变量需要使用关键字var&#xff0c;然后输入变量的名称。 1 var myvar; 定义一个变量后&#xff0c;可以赋予变量一个值&#xff1a; 1 myvar "mxp"; 可以将上述操作写在一行&#x…

spring面试专题一点通,再也不用担心面试不会回答了

前言文章内容有点小长&#xff0c;希望你能耐心阅读&#xff0c;更多Java面试题以及学习资料获取方式&#xff1a;加Qun:1017-599-436免费获取。还有更多包括电子书&#xff0c;PDF文档以及视频精讲可以分享给大家&#xff0c;内容覆盖很广&#xff0c;分布式缓存、RPC 调用、Z…

bzoj4033 [HAOI2015]树上染色

题目&#xff1a;https://www.lydsy.com/JudgeOnline/problem.php?id4033 重要的思路&#xff1a;与其考虑每一个点对的贡献&#xff0c;不如考虑每条边的贡献&#xff08;被经过了几次&#xff09;&#xff01; 树形dp。 总共的黑点和白点的个数都是已知的&#xff0c;所以知…

JavaScript --- 表单focus,blur,change事件的实现

假设有一个文本框&#xff0c;我们只允许用户输入数值。为此&#xff0c;我们希望: 1.利用focus事件修改文本框内容&#xff0c; 2.利用blur事件回复文本框的内容, 3.利用change事件在用户输入了非数值字符时再次修改背景颜色。 var EventUtil {addHandler: function(element…

mysql日期格式转化

select DATE_FORMAT( 20170701, %Y-%m-%d);先挖坑转载于:https://www.cnblogs.com/tuhooo/p/7766221.html

Solr管理页面 上

DashBoard&#xff08;仪表盘&#xff09;Logging&#xff08;日志&#xff09;Core Admin&#xff08;Core管理&#xff09;在Solr中&#xff0c;每一个Core&#xff0c;代表一个索引库&#xff0c;里面包含索引数据及其配置信息。Solr中可以拥有多个Core&#xff0c;也就同时…

GRPC协议的相关原理

GRPC的Client与Server&#xff0c;均通过Netty Channel作为数据通信&#xff0c;序列化、反序列化则使用Protobuf&#xff0c;每个请求都将被封装成HTTP2的Stream&#xff0c;在整个生命周期中&#xff0c;客户端Channel应该保持长连接&#xff0c;而不是每次调用重新创建Chann…

Echarts --- 各个省份的坐标

纯手打…效果如下 1.新疆: [86.61 , 40.79] 2.西藏:[89.13 , 30.66] 3.黑龙江:[128.34 , 47.05] 4.吉林:[126.32 , 43.38] 5.辽宁:[123.42 , 41.29] 6.内蒙古:[112.17 , 42.81] 7.北京:[116.40 , 40.40 ] 8.宁夏:[106.27 , 36.76] 9.山西:[111.95,37.65] 10.河北:[115.21 , 38.…

xxx征集系统项目目标文档

问题 每四人一组&#xff0c;讨论结束后&#xff0c;每人根据课堂讨论结果提交一份系统利益相关者案例。撰写撰写项目目标文档&#xff08;目标&#xff0c;好处&#xff0c;度量标准。&#xff09; 项目目标文档 目标&#xff1a; &#xff08;1&#xff09;需求填报 &#xf…

高并发大流量专题---10、MySQL数据库层的优化

高并发大流量专题---10、MySQL数据库层的优化 一、总结 一句话总结&#xff1a; mysql先考虑做分布式缓存&#xff0c;过了缓存后就做mysql数据库层面的优化 1、mysql数据库层的优化的前面一层是什么&#xff1f; 数据库缓存&#xff1a;突破了数据库缓存就需要做mysql数据库层…

【彩彩只能变身队】后端工作总结

2018.06.09 早上8点到晚上10点 冲刺前后端交互(vueexpressmysql) 8&#xff1a;00-12&#xff1a;00 &#xff1a; 前端把请求写好&#xff1a; <template> <div class"LoginForm"> <el-form ref"form" label-width"80px"…

web安全

web安全 DOS命令 web攻防必备课笔记 慕课xss学习 阮一峰&#xff1a;MVC、MVP和MVVM的图示转载于:https://www.cnblogs.com/hanxuming/p/7774092.html

JavaScript --- 渲染数据量大的数组

很多时候&#xff0c;需要在页面上展示从后台来的大量数据,如果一次性渲染&#xff0c;会影响用户的体验。(而且浏览器中的JS严格限制了资源) /* *使用分组的思想来渲染大量的数组 *parmas array 要处理的数组 *params process 对数组中每一个item进行的操作 *parmas context …

Jquery操作select小结

每次操作select都要查资料&#xff0c;干脆总结一下。 为select设置placeholder <select class"form-control selOP" placeholder"Pick Orchestration Plan"><option value"" disabled selected styledisplay:none;>Pick Orchestrat…

第六讲:PrintClient工具的使用

一些简单命令&#xff1a; cp -rf 源目录 目的目录 chmod -R 777 文件名 motelist 查看节点路径 make telosb 编译代码 make telosb reinstall 下载但不编译 make telosb install 编译并且下载 make telosb install, 2 bsl,/dev/ttyUSB0 下载指定路径 java net.tinyos.tools.Li…

SQL Server

查看数据库服务器名称&#xff1a;tracert 192.168.10.01 转载于:https://www.cnblogs.com/hongwei2085/p/9174760.html

css --- 选择器

标签选择器 // 标签选择器是最简单的选择器, 它的命名只要和对应的HTML标签相同即可 h1 {font-size: 30px;color: #333; }类选择器 // 类选择器也称为class选择器,它的语法非常简单,在class名称前面加上一个"."符号 <div class"red content"></…

C++标准输入流、输出流以及文件流

1、流的控制 iomanip 在使用格式化I/O时应包含此头文件。 stdiostream 用于混合使用C和C 的I/O机制时&#xff0c;例如想将C程序转变为C程序 2、类继承关系 ios是抽象基类&#xff0c;由它派生出istream类和ostream类&#xff0c; iostream类支持输入输出操作&…

Hadoop学习笔记—8.Combiner与自定义Combiner

一、Combiner的出现背景 1.1 回顾Map阶段五大步骤 在第四篇博文《初识MapReduce》中&#xff0c;我们认识了MapReduce的八大步凑&#xff0c;其中在Map阶段总共五个步骤&#xff0c;如下图所示&#xff1a; 其中&#xff0c;step1.5是一个可选步骤&#xff0c;它就是我们今天需…