(一)BFS

1.地牢大师

你现在被困在一个三维地牢中,需要找到最快脱离的出路!

地牢由若干个单位立方体组成,其中部分不含岩石障碍可以直接通过,部分包含岩石障碍无法通过。

向北,向南,向东,向西,向上或向下移动一个单元距离均需要一分钟。

你不能沿对角线移动,迷宫边界都是坚硬的岩石,你不能走出边界范围。

请问,你有可能逃脱吗?

如果可以,需要多长时间?

输入格式

输入包含多组测试数据。

每组数据第一行包含三个整数 L,R,C 分别表示地牢层数,以及每一层地牢的行数和列数。

接下来是 L 个 R 行 C 列的字符矩阵,用来表示每一层地牢的具体状况。

每个字符用来描述一个地牢单元的具体状况。

其中, 充满岩石障碍的单元格用”#”表示,不含障碍的空单元格用”.”表示,你的起始位置用”S”表示,终点用”E”表示。

每一个字符矩阵后面都会包含一个空行。

当输入一行为”0 0 0”时,表示输入终止。

输出格式

每组数据输出一个结果,每个结果占一行。

如果能够逃脱地牢,则输出”Escaped in x minute(s).”,其中X为逃脱所需最短时间。

如果不能逃脱地牢,则输出”Trapped!”。

数据范围

1≤L,R,C≤100

输入样例:

3 4 5
S....
.###.
.##..
###.# #####
#####
##.##
##... #####
#####
#.###
####E 1 3 3
S##
#E#
### 0 0 0

输出样例:

Escaped in 11 minute(s).
Trapped! 解题思路:一道三维的BFS搜索题,我们可以建立三个移动数组:vx,vy,vk,分别表示北,南,东,西,上,下,设置一个三维的map数组来存储地图,
设置一个vis数组,用来判断是否走过以及距离。
代码:
#include<iostream>
#include<queue>
#include<cstring>
using namespace std;
const int N=;
int l,r,c;
char map[N][N][N];
int vis[N][N][N];
int vx[]={,-,,,,};
int vy[]={,,,-,,};
int vk[]={,,,,,-};
typedef struct Node
{
int k,x,y;
};
bool check(int K,int X,int Y)
{
if(X<||X>=r||Y<||Y>=c||K<||K>=l)
return false;
if(map[K][X][Y]=='#')
return false;
if(vis[K][X][Y]!=)
return false;
return true;
}
int bfs(Node start)
{
queue<Node> q;
memset(vis,,sizeof(vis));
q.push(start);
while(!q.empty())
{
Node tem=q.front();
if(map[tem.k][tem.x][tem.y]=='E')
return vis[tem.k][tem.x][tem.y];
q.pop();
for(int i=;i<;i++)
{
int X=tem.x+vx[i];
int Y=tem.y+vy[i];
int K=tem.k+vk[i];
if(check(K,X,Y)==false)
continue;
vis[K][X][Y]=vis[tem.k][tem.x][tem.y]+;
Node t={K,X,Y};
q.push(t);
}
}
return ;
} int main()
{
int i,j,bx,by,bk,k;
Node start;
string ss;
while()
{
cin>>l>>r>>c;
if(l==&&r==&&c==)
break;
for(k=;k<l;k++)
{
for(i=;i<r;i++)
{
for(j=;j<c;j++)
{
cin>>map[k][i][j];
if(map[k][i][j]=='S')
{
bk=k,bx=i,by=j;
start={bk,bx,by};
}
}
}
getline(cin,ss);
}
int ans=bfs(start);
if(ans)
cout<<"Escaped in "<<ans<<" minute(s)."<<endl;
else
cout<<"Trapped!"<<endl;
}
return ;
}

2.全球变暖

你有一张某海域 N×N 像素的照片,”.”表示海洋、”#”表示陆地,如下所示:

.......
.##....
.##....
....##.
..####.
...###.
.......

其中”上下左右”四个方向上连在一起的一片陆地组成一座岛屿,例如上图就有 2 座岛屿。

由于全球变暖导致了海面上升,科学家预测未来几十年,岛屿边缘一个像素的范围会被海水淹没。

具体来说如果一块陆地像素与海洋相邻(上下左右四个相邻像素中有海洋),它就会被淹没。

例如上图中的海域未来会变成如下样子:

.......
.......
.......
.......
....#..
.......
.......

请你计算:依照科学家的预测,照片中有多少岛屿会被完全淹没。

输入格式

第一行包含一个整数N。

以下 N 行 N 列,包含一个由字符”#”和”.”构成的 N×N 字符矩阵,代表一张海域照片,”#”表示陆地,”.”表示海洋。

照片保证第 1 行、第 1 列、第 N 行、第 N 列的像素都是海洋。

输出格式

一个整数表示答案。

数据范围

1≤N≤1000

输入样例1:

7
.......
.##....
.##....
....##.
..####.
...###.
.......

输出样例1:

1

输入样例2:

9
.........
.##.##...
.#####...
.##.##...
.........
.##.#....
.#.###...
.#..#....
.........

输出样例2:

1
 解题思路:该题要找出完全被淹没的岛屿的个数,首先我们要做的是找出所有的联通快,我们可以用bfs来找,对于每一个联通快我们需要判断他是否被完全淹没,如何判断呢?
我们可以找出该联通块里一共有多少个像素,再找出有多少个像素与海相邻,如果两者的个数相等,那么该岛屿必然会被完全淹没。
否则,不会完全淹没。特别注意:当你用bfs开始寻找时,此时的像素总数的初始值为1.
代码:
#include<iostream>
#include<cstring>
#include<queue>
#include<cstdio>
using namespace std;
const int N=;
char map[N][N];
bool ts[N][N];
int vx[]={,-,,};
int vy[]={,,,-};
int ans,n;
typedef struct Node
{
int x,y;
};
bool check(int X,int Y)
{
if(X<||X>=n||Y<||Y>=n)
return false;
if(map[X][Y]=='.')
return false;
if(ts[X][Y]==true)
return false;
return true;
}
void bfs(int i,int j)
{
Node start={i,j};
queue<Node> q;
ts[i][j]=true;
q.push(start);
int total=,ver=;
while(q.size())
{
Node t=q.front();
q.pop();
int flag=false;
for(i=;i<;i++)
{
int X=t.x+vx[i];
int Y=t.y+vy[i];
if(X>=&&X<n&&Y>=&&Y<n&&map[X][Y]=='.')
{
flag=true;
}
if(check(X,Y)==false)
continue;
total++;
ts[X][Y]=true;
Node f={X,Y};
q.push(f);
}
if(flag)
ver++;
}
if(total==ver)
ans++;
}
int main()
{
int i,j;
cin>>n;
for(i=;i<n;i++)
{
for(j=;j<n;j++)
{
cin>>map[i][j];
}
}
for(i=;i<n;i++)
{
for(j=;j<n;j++)
{
if(!ts[i][j]&&map[i][j]=='#')
{
bfs(i,j);
}
}
}
cout<<ans;
return ;
}

3.完全二叉树的权值

给定一棵包含 N 个节点的完全二叉树,树上每个节点都有一个权值,按从上到下、从左到右的顺序依次是 A1,A2,⋅⋅⋅AN,如下图所示:

现在小明要把相同深度的节点的权值加在一起,他想知道哪个深度的节点权值之和最大?

如果有多个深度的权值和同为最大,请你输出其中最小的深度。

注:根的深度是 1。

输入格式

第一行包含一个整数 N。

第二行包含 N 个整数 A1,A2,⋅⋅⋅AN。

输出格式

输出一个整数代表答案。

数据范围

1≤N≤105,
−105≤Ai≤105

输入样例:

7
1 6 5 4 3 2 1

输出样例:

2
解题思路:每一层的个数都是=2n-1个,而且开头的下标都是2的倍数
代码:
#include<iostream>
using namespace std;
const int N=;
typedef long long ll;
ll a[N];
ll maxn,sum,ans;
int main()
{
ll i,j,n,k;
cin>>n;
for(i=;i<=n;i++)
cin>>a[i];
maxn=a[];
ans=;
k=;
for(i=;i<=n;i=i*)
{
sum=;
for(j=i;j<=i*-&&j<=n;j++)
{
sum+=a[j];
}
k++;
if(sum>maxn)
{
maxn=sum;
ans=k;
}
}
cout<<ans;
return ;
}
 

双指针,BFS和图论(二)的更多相关文章

  1. SDUT 2142 数据结构实验之图论二:基于邻接表的广度优先搜索遍历

    数据结构实验之图论二:基于邻接表的广度优先搜索遍历 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Descript ...

  2. 双指针,BFS与图论(一)

    (一)双指针 1.日志统计 小明维护着一个程序员论坛.现在他收集了一份”点赞”日志,日志共有 N 行. 其中每一行的格式是: ts id 表示在 ts 时刻编号 id 的帖子收到一个”赞”. 现在小明 ...

  3. 双指针,BFS和图论(三)

    (一)图论 1.大臣的旅费 很久以前,T王国空前繁荣. 为了更好地管理国家,王国修建了大量的快速路,用于连接首都和王国内的各大城市. 为节省经费,T国的大臣们经过思考,制定了一套优秀的修建方案,使得任 ...

  4. SDUT2142数据结构实验之图论二:基于邻接表的广度优先搜索遍历

    http://acm.sdut.edu.cn/sdutoj/showproblem.php?pid=2142&cid=1186 题目描述 给定一个无向连通图,顶点编号从0到n-1,用广度优先搜 ...

  5. 数据结构实验之图论二:图的深度遍历(SDUT 2107)(简单DFS)

    题解:图的深度遍历就是顺着一个最初的结点开始,把与它相邻的结点都找到,也就是一直往下搜索直到尽头,然后在顺次找其他的结点. #include <bits/stdc++.h> using n ...

  6. 数据结构之 图论---bfs(邻接表)

    数据结构实验之图论二:基于邻接表的广度优先搜索遍历 Time Limit: 1000MS Memory limit: 65536K 题目描述 给定一个无向连通图,顶点编号从0到n-1,用广度优先搜索( ...

  7. 图论相关知识(DFS、BFS、拓扑排序、最小代价生成树、最短路径)

    图的存储 假设是n点m边的图: 邻接矩阵:很简单,但是遍历图的时间复杂度和空间复杂度都为n^2,不适合数据量大的情况 邻接表:略微复杂一丢丢,空间复杂度n+m,遍历图的时间复杂度为m,适用情况更广 前 ...

  8. hdu 1240 Asteroids!(BFS)

    题目链接:点击链接 简单BFS,和二维的做法相同(需注意坐标) 题目大意:三维的空间里,给出起点和终点,“O”表示能走,“X”表示不能走,计算最少的步数 #include <iostream&g ...

  9. 剪邮票dfs+bfs+组合+结构体

    #include<iostream>#include<queue>using namespace std;struct Point{ int x; int y; };queue ...

随机推荐

  1. Yet Another Array Queries Problem CodeForces - 863D (暴力/思维)

    You are given an array a of size n, and q queries to it. There are queries of two types: 1 li ri — p ...

  2. E420笔记本升级固态硬盘

      后壳比较好拆   机械硬盘盒 这里 可费了好大劲 才 拧开这 4个螺丝 光驱支架买的这个38-5rmb,京东自提       以前不知道的一件事: 原来的光驱挡板要自己拆下来换到新买的光驱支架上面 ...

  3. freemarker<三>

    前两篇博客介绍了freemaker是什么以及简单的语法规则,下面我们通过实现一个demo来看在实际应用中如何使用freemaker,本篇博客主要介绍freemaker与spring的整合. 需要的Ja ...

  4. Django发送邮件方法

    在Django中将渲染后的模板进行邮件发送,可以使用send_email方法 首先在settings.py中添加如下配置 # 邮件配置SSL加密方式 EMAIL_HOST = 'smtp.qq.com ...

  5. 019 Ceph整合openstack

    一.整合 glance ceph 1.1 查看servverb关于openstack的用户 [root@serverb ~]# vi ./keystonerc_admin unset OS_SERVI ...

  6. Spring Security入门(基于SSM环境配置)

    一.前期准备 配置SSM环境 二.不使用数据库进行权限控制 配置好SSM环境以后,配置SpringSecurity环境 添加security依赖   <dependency> <gr ...

  7. CSS布局方式--inline-block 布局

    布局其实就是想办法怎样将一些元素横向的排列起来,纵向由于块级元素的存在会自动占据一行. inline-block 元素会占据一行而且可以调整宽高很适合将这些元素排列在一行,而且使用 inline-bl ...

  8. 【5min+】 什么?原来C#还有这两个关键字

    系列介绍 简介 [五分钟的dotnet]是一个利用您的碎片化时间来学习和丰富.net知识的博文系列.它所包含了.net体系中可能会涉及到的方方面面,比如C#的小细节,AspnetCore,微服务中的. ...

  9. Linux开发环境及应用—《第三周单元测验》《第四周单元测验》

    三单元 1.vi处于文本输入状态时,按下下列哪个按键可以返回命令状态?C A.^ B.$ C.Esc D- 2.vi处于命令状态时,按下下列哪组按键可以把正在编辑的内容保存到磁盘上?D A.Ctrl- ...

  10. 设置本地上网IP

    在局域网中,我们经常需要根据网络连接环境来对本地连接的IP地址进行手动设置,那么如何对IP地址进行设置呢?下面小编就把教程介绍给大家. 1. 右击桌面“网上邻居”->选择“属性”,打开“网络共享 ...