挑战程序2.1.5 穷竭搜索>>宽度优先搜索
先对比一下DFS和BFS
深度优先搜索DFS 宽度优先搜索BFS


明显可以看出搜索顺序不同。
DFS是搜索单条路径到底部,再回溯。
BFS是搜索近的状态,直到底部,一般在求解最短路径或者最短步数上应用。
BFS要用到队列呢。。
队列的用法看一看
map的基本操作函数: C++Maps 是一种关联式容器,包含“关键字/值”对 begin() 返回指向map头部的迭代器 clear() 删除所有元素 count() 返回指定元素出现的次数 empty() 如果map为空则返回true end() 返回指向map末尾的迭代器 equal_range() 返回特殊条目的迭代器对 erase() 删除一个元素 find() 查找一个元素 get_allocator() 返回map的配置器 insert() 插入元素 key_comp() 返回比较元素key的函数 lower_bound() 返回键值>=给定元素的第一个位置 max_size() 返回可以容纳的最大元素个数 rbegin() 返回一个指向map尾部的逆向迭代器 rend() 返回一个指向map头部的逆向迭代器 size() 返回map中元素的个数 swap() 交换两个map upper_bound() 返回键值>给定元素的第一个位置 value_comp() 返回比较元素value的函数
map的简单操作函数
练习题系列………………………………………………………
因为步数(折返)的问题撸了一天。。
如果那个点可以走,那么就推入队列,等待搜索。
#include <stdio.h>
#include <queue>
#include <string.h>
using namespace std;
][],step[][];
typedef pair<int, int> P;
struct stu{
int x; int y; int t;
};
];
]={, , , -, };
]={, , , , -};
void zha(int M) {
memset(map1, -, sizeof(map1));
; i < M; i++)
; k < ; k++){//five points are burst.
int nx = ch[i].x + dx[k];
int ny = ch[i].y + dy[k];
&& nx < && ny >= && ny < && (ch[i].t < map1[ny][nx] || map1[ny][nx] == -))
map1[ny][nx] = ch[i].t;//give everypoint the minimum burst time.
}
}
int bfs() {
queue <P> que;
que.push( P (, ));
memset(step, -, sizeof(step));
step[][]=;
while(que.size()) {
P p= que.front();
que.pop();
){//find map1's -1 and print it
return step[p.first][p.second];
}
if(step[p.first][p.second] >= map1[p.first][p.second])continue;//the point had benn burst,so jump it
; i < ; i++) {//this is the point of four diretions that does not been destroy.
int nx = p.first + dx[i],ny = p.second + dy[i];
&& ny >= &&step[nx][ny] == -)//if it can arrive and does not exceed the map
{
que.push(P(nx, ny));//push it to the queue and go
step[nx][ny]=step[p.first][p.second]+;//of course,step must add 1 when go.
}
}
}
;
}
int main()
{
int M,a;
while(~scanf("%d",&M))
{
; i<M; i++)
scanf("%d%d%d",&ch[i].x,&ch[i].y,&ch[i].t);
zha(M);
a=bfs();
printf("%d\n",a);
}
;
}
POJ3669
还是要用个地图标记一下步数,不然会计算错误。
#include <iostream>
#include <queue>
#include <string.h>
using namespace std;
typedef pair<int, int> P;
int sx,sy,H,W,N;
][];
][];
] = {,,-,};
] = {,,,-};
void find1(int g){
; i < W; i++)
; k < H; k++)
)){
if(map1[i][k] == 'S') map1[i][k] ='.';
sx = i; sy = k;
return ;
}
}
int bfs(int n)
{
memset(step,-,sizeof(step));
queue <P> que;
que.push(P (sx,sy));
step[sx][sy] = ;
while(que.size()){
int x = que.front().first, y = que.front().second;
que.pop();
; i < ; i++){
int xn = x + dx[i], yn = y + dy[i];
&& xn < W && yn >= && yn < H && map1[xn][yn] != )
{
step[xn][yn] = step[x][y] + ;
))
{
return step[xn][yn];
}
que.push(P(xn, yn));
}
}
}
;
}
int main()
{
cin >> W >> H >> N;
; i < W; i++)
; k < H; k++)
cin >> map1[i][k];
;
find1();
step += bfs();
; i < N; i++)
{
find1(i);
step += bfs(i+);
}
cout << step << endl;
;
}
AOJ0558
#include <iostream>
#include <queue>
#include <string.h>
#include <map>
#include <algorithm>
using namespace std;
]={ , -, , -};
map<string, int> dp;
void bfs(){
queue<string> que;
que.push(");
dp[;
while(que.size()){
string now =que.front();
que.pop();
;
; j < ; j++)
'){
p=j;
break;
}
; i < ; i++){
int pn= p + d[i];
&& pn < && !(p == && i == )
&& !(p == && i == )){
string next = now;
swap(next[p],next[pn]);
if(dp.find(next) == dp.end()){
dp[next] = dp[now] + ;
que.push(next);
}
}
}
}
return ;
}
int main()
{
string line;
bfs();
while(getline(cin,line))
{
line.erase(remove(line.begin(), line.end(), ' '), line.end());
cout << dp[line] << endl;
}
;
}
AOJ0121
挑战程序2.1.5 穷竭搜索>>宽度优先搜索的更多相关文章
- 挑战程序2.1.4 穷竭搜索>>深度优先搜索
深度优先搜索DFS,从最开始状态出发,遍历一种状态到底,再回溯搜索第二种. 题目:POJ2386 思路:(⊙v⊙)嗯 和例题同理啊,从@开始,搜索到所有可以走到的地方,把那里改为一个值(@或者 ...
- 【算法入门】广度/宽度优先搜索(BFS)
广度/宽度优先搜索(BFS) [算法入门] 1.前言 广度优先搜索(也称宽度优先搜索,缩写BFS,以下采用广度来描述)是连通图的一种遍历策略.因为它的思想是从一个顶点V0开始,辐射状地优先遍历其周围较 ...
- 搜索与图论②--宽度优先搜索(BFS)
宽度优先搜索 例题一(献给阿尔吉侬的花束) 阿尔吉侬是一只聪明又慵懒的小白鼠,它最擅长的就是走各种各样的迷宫. 今天它要挑战一个非常大的迷宫,研究员们为了鼓励阿尔吉侬尽快到达终点,就在终点放了一块阿尔 ...
- [宽度优先搜索] FZU-2150 Fire Game
Fat brother and Maze are playing a kind of special (hentai) game on an N*M board (N rows, M columns) ...
- 【BFS宽度优先搜索】
一.求所有顶点到s顶点的最小步数 //BFS宽度优先搜索 #include<iostream> using namespace std; #include<queue> # ...
- 层层递进——宽度优先搜索(BFS)
问题引入 我们接着上次“解救小哈”的问题继续探索,不过这次是用宽度优先搜索(BFS). 注:问题来源可以点击这里 http://www.cnblogs.com/OctoptusLian/p/74296 ...
- BFS算法的优化 双向宽度优先搜索
双向宽度优先搜索 (Bidirectional BFS) 算法适用于如下的场景: 无向图 所有边的长度都为 1 或者长度都一样 同时给出了起点和终点 以上 3 个条件都满足的时候,可以使用双向宽度优先 ...
- 宽度优先搜索--------迷宫的最短路径问题(dfs)
宽度优先搜索运用了队列(queue)在unility头文件中 源代码 #include<iostream>#include<cstdio>#include<queue&g ...
- 算法基础⑦搜索与图论--BFS(宽度优先搜索)
宽度优先搜索(BFS) #include<cstdio> #include<cstring> #include<iostream> #include<algo ...
随机推荐
- MySQL 实现row_number() 分组排序功能
数据库基本脚本 CREATE TABLE `a` ( `ID` INT(10) NULL DEFAULT NULL, `class` INT(10) NULL DEFAULT NULL, `score ...
- LINUX端口查看
e切依燃 LINUX端口查看 查看文件数 ls | wc -w lsof -i:80
- 早上遇到err_content_decoding_fail错误
网站在手机端出现一个error: err_content_decoding_fail. 查了一下,应该是文件编码出问题了. 但这两天都很小代码级别的改动,编码的问题一般都是会在覆盖文件的时候才出现. ...
- android中如何获取xml界面里的非自定义属性
获取自定义属性大家都很熟悉了,就不多说了(定义declare-styleable,context.obtainStyledAttributes巴拉巴拉...) 下面我们说一下怎么获取非自定义的属性,比 ...
- LeetCode Paint House
原题链接在这里:https://leetcode.com/problems/paint-house/ 题目: There are a row of n houses, each house can b ...
- alert()、confirm()和prompt()的区别与用法
1.警告消息框alertalert 方法有一个参数,即希望对用户显示的文本字符串.该字符串不是 HTML 格式.该消息框提供了一个"确定"按钮让用户关闭该消息框,并且该消息框是模式 ...
- js 实现类似php函数number_format的功能
今天同事在做一个功能的时候需要使用js来实现类似php函数number_format的功能,最后就有了下面的方法,可以实现了: /** * number_format * @param number ...
- 向指定URL发送GET方法获取资源,编码问题。 Rest风格
http编码.今天遇到获取网页上的数据,用HTTP的GET请求访问url获取资源,网上有相应的方法.以前一直不知道什么事rest风格,现在我想就是开一个Controller,然后使人可以调用你的后台代 ...
- Android 主题切换 小结
前言 我们用手机的时候经常看到 设置里面有夜间模式和白天模式来更换APP的主题,以前以为很简单,但是实际做起来还是有各种不完美,那么我们也要去了解各种解决方案来丰富我们的知识,现在我们就来看看各种优劣 ...
- Select2个人使用总结
最近项目有功能需要使用列表选多个用户,老夫偷懒使用zTree进行了多级checktree实现,不过貌似太丑,虽然对于我这种后端来说无所谓,但强迫症还是让我寻找其他代替控件. 闲话不说了,先上Selec ...