(一)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. mysql修改数据库密码

    方法1: 运行MySQL 5.7 Command Line Client,输入老的密码: use mysql: update user set authentication_string=passwo ...

  2. mangoDB 储存 id为objectid

  3. Java中大量if...else语句的消除替代方案

    在我们平时的开发过程中,经常可能会出现大量If else的场景,代码显的很臃肿,非常不优雅.那我们又没有办法处理呢? 针对大量的if嵌套让代码的复杂性增高而且难以维护.本文将介绍多种解决方案. 案例 ...

  4. VIM 用正则表达式,非贪婪匹配,匹配竖杠,竖线, 匹配中文,中文正则,倒数第二列, 匹配任意一个字符 :

    VIM 用正则表达式 批量替换文本,多行删除,复制,移动 在VIM中 用正则表达式 批量替换文本,多行删除,复制,移动 :n1,n2 m n3     移动n1-n2行(包括n1,n2)到n3行之下: ...

  5. mysql5.7密码修改与报错分析

    1.修改密码 修改密码: vim /etc/my.cnf 的mysqld字段加入skip-grant-tables 重启MySQL,service mysqld restart 终端输入 mysql ...

  6. iDrac6 虚拟控制台 连接失败

    最近给公司的服务器升级硬件(其实是服务器要淘汰了,公司就不管了,爱怎么折腾就怎么折腾,只要不坏就行) 服务器配置:Dell PowerEdge R610,E5606 x2(双路2.13G 4核4线程) ...

  7. 浮点数NaN和INF(#IND, #INF)

    NaN&INF定义在一些情况会出现无效的浮点数,例如除0,例如负数求平方根等,像这类情况,获取到的浮点数的值是无效的. NaN 即 Not a Number         非数字 INF  ...

  8. RecursiveTask和RecursiveAction的使用总结

    一:什么是Fork/Join框架    Fork/Join框架是Java7提供了的一个用于并行执行任务的框架, 是一个把大任务分割成若干个小任务,最终汇总每个小任务结果后得到大任务结果的框架.我们再通 ...

  9. 多线程之美8一 AbstractQueuedSynchronizer源码分析<二>

    目录 AQS的源码分析 该篇主要分析AQS的ConditionObject,是AQS的内部类,实现等待通知机制. 1.条件队列 条件队列与AQS中的同步队列有所不同,结构图如下: 两者区别: 1.链表 ...

  10. Zeus,一个可以快速使用微服务组件

    去年(上周)一直准备着做一个分布式微服务的组件,可以让使用者用最简单的方式引入,只需要使用简单的注解就能够使用. 用一点一点的空闲时间终于堆出来一个暂时可用的zeus-1.0版本. Zeus,意为宙斯 ...