挑战程序2.1.4 穷竭搜索>>深度优先搜索
深度优先搜索DFS,从最开始状态出发,遍历一种状态到底,再回溯搜索第二种。
题目:POJ2386
/*
input:
7 7
..#.#..
..#.#..
###.###
...@...
###.###
..#.#..
..#.#.. 表示有13个可以走到的地方(包括原来那一格)。*/
#include <stdio.h>
][];
void solve(int H,int W);
void find1(int H,int W);
void dfs(int x,int y,int H,int W);
int main()
{
int H,W,i;
&&W!=)
{
getchar();
;i<H;i++)
gets(ch[i]);
find1(H,W);
solve(H,W);
}
;
}
void solve(int H,int W)
{
;
;i<H;i++)
;k<W;k++)
if(ch[i][k]=='@')
a++;
printf("%d\n",a);
}
void find1(int H,int W)
{
;i<H;i++)
;k<W;k++)
if(ch[i][k]=='@')
{
dfs(i,k,H,W);
return;
}
}
void dfs(int x,int y,int H,int W)
{
int x1,y1,nx,ny;
ch[x][y]='@';
;x1<=;x1++)
{
nx=x+x1;
&&nx<H&&ch[nx][y]!='#'&&ch[nx][y]!='@')
dfs(nx,y,H,W);
}
;y1<=;y1++)
{
ny=y+y1;
&&ny<W&&ch[x][ny]!='#'&&ch[x][ny]!='@')
dfs(x,ny,H,W);
}
return;
}
POJ2386
练习题系列………………………………………………………
#include <stdio.h>
][];
void solve(int H,int W);
void find1(int H,int W);
void dfs(int x,int y,int H,int W);
int main()
{
int H,W,i;
&&W!=)
{
getchar();
;i<H;i++)
gets(ch[i]);
find1(H,W);
solve(H,W);
}
;
}
void solve(int H,int W)//计数
{
;
;i<H;i++)
;k<W;k++)
if(ch[i][k]=='@')
a++;
printf("%d\n",a);
}
void find1(int H,int W)//找到点
{
;i<H;i++)
;k<W;k++)
if(ch[i][k]=='@')
{
dfs(i,k,H,W);
return;
}
}
void dfs(int x,int y,int H,int W)
{
int x1,y1,nx,ny;
ch[x][y]='@';
;x1<=;x1++)
{
nx=x+x1;
&&nx<H&&ch[nx][y]!='#'&&ch[nx][y]!='@')
dfs(nx,y,H,W);
}
;y1<=;y1++)
{
ny=y+y1;
&&ny<W&&ch[x][ny]!='#'&&ch[x][ny]!='@')
dfs(x,ny,H,W);
}
return;
}
POJ1979
#include <stdio.h>
#include <iostream>
using namespace std;
][];
]={,,,-};
]={,,-,};
int H,W,cou;
void DFS(int x, int y){
;
char b=ch[x][y];
ch[x][y]='.';
; i < ; i++)
{
int xn = x + xx[i], yn = y + yy[i];
&& xn < W && yn >= && yn < H && ch[xn][yn] == b)
{
DFS(xn, yn);
}
}
return ;
}
int main()
{
while(cin >> W >> H && (H && W))
{
cou = ;
; i < W; i++)
; k < H; k++)
cin >> ch[i][k];
; i < W; i++)
; k < H; k++)
if(ch[i][k] != '.')
{
DFS(i, k);
cou++;
}
cout << cou << endl;
}
;
}
AOJ0033
题目:POJ3009
这题撸了很久。
#include <iostream>
#include <string.h>
#include <algorithm>
using namespace std;
]={ , , -, };
]={ , , , -};
][];
int xn,yn,x1,y1,H,W,y2,x2,a;
void dfs(int x1, int y1, int step){
) return ;
; i < ; i++){//四个方向
int xn = x1 + dx[i], yn = y1 + dy[i];
if(xn == x2 && yn == y2){
a=min(a, step + );
continue;
}
)continue;
&& xn < W && yn >= && yn < H){
xn += dx[i]; yn += dy[i];//继续往下面走
&& xn < W && yn >= && yn < H)
{
) continue;//直到撞墙或终点
if(xn == x2 && yn == y2){//到达终点
a= min(a, step + );
return ;
}
map1[xn][yn] = ;//停下来了,继续dfs,注意dfs前后面的墙。
dfs(xn - dx[i], yn - dy[i], step + );
map1[xn][yn] = ;
break;
}
}
}
return ;
}
int main()
{
&& W != ){
; i < W; i++)
; k < H; k++){
cin >> map1[i][k];
){
x1 = i; y1 = k;
map1[i][k] = ;
}
){
x2 = i;
y2 = k;
map1[i][k] = ;
}
}
a = ;
dfs(x1, y1, );
|| a>) cout << "-1" << endl;
else cout << a <<endl;
}
;
}
POJ3009
挑战程序2.1.4 穷竭搜索>>深度优先搜索的更多相关文章
- 挑战程序2.1.5 穷竭搜索>>宽度优先搜索
先对比一下DFS和BFS 深度优先搜索DFS 宽度优先搜索BFS 明显可以看出搜索顺序不同. DFS是搜索单条路径到 ...
- 常用算法2 - 广度优先搜索 & 深度优先搜索 (python实现)
1. 图 定义:图(Graph)是由顶点的有穷非空集合和顶点之间边的集合组成,通常表示为:G(V,E),其中,G表示一个图,V是图G中顶点的集合,E是图G中边的集合. 简单点的说:图由节点和边组成.一 ...
- 搜索——深度优先搜索(DFS)
设想我们现在身处一个巨大的迷宫中,我们只能自己想办法走出去,下面是一种看上去很盲目但实际上会很有效的方法. 以当前所在位置为起点,沿着一条路向前走,当碰到岔道口时,选择其中一个岔路前进.如果选择的这个 ...
- 【数据结构与算法Python版学习笔记】图——骑士周游问题 深度优先搜索
骑士周游问题 概念 在一个国际象棋棋盘上, 一个棋子"马"(骑士) , 按照"马走日"的规则, 从一个格子出发, 要走遍所有棋盘格恰好一次.把一个这样的走棋序列 ...
- python实现广度优先搜索和深度优先搜索
图的概念 图表示的是多点之间的连接关系,由节点和边组成.类型分为有向图,无向图,加权图等,任何问题只要能抽象为图,那么就可以应用相应的图算法. 用字典来表示图 这里我们以有向图举例,有向图的邻居节点是 ...
- 《挑战程序设计竞赛》2.1 穷竭搜索 POJ2718 POJ3187 POJ3050 AOJ0525
POJ2718 Smallest Difference Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6509 Acce ...
- 《挑战程序设计竞赛》2.1 深度优先搜索 POJ2386 POJ1979 AOJ0118 AOJ0033 POJ3009
POJ2386 Lake Counting Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 25366 Accepted: ...
- matlab练习程序(广度优先搜索BFS、深度优先搜索DFS)
如此经典的算法竟一直没有单独的实现过,真是遗憾啊. 广度优先搜索在过去实现的二值图像连通区域标记和prim最小生成树算法时已经无意识的用到了,深度优先搜索倒是没用过. 这次单独的将两个算法实现出来,因 ...
- 深度优先搜索(dfs)与出题感想
在3月23号的广度优先搜索(bfs)博客里,我有提到写一篇深搜博客,今天来把这个坑填上. 第一部分:深度优先搜索(dfs) 以上来自百度百科. 简单来说,深度优先搜索算法就是——穷举法,即枚举所有情况 ...
随机推荐
- 制作手机相册 全屏滚动插件fullpage.js
今天是端午自己做了一个小的送祝福链接 这里用到了fullpage插件 $('#container').fullpage({ navigation: false, //navigatio ...
- MYSQL相关完整笔记
useradd mysql -s /sbin/nologin cat/etc/passwd | grep mysqlcat /etc/group | grep mysql 源目录 cd /usr/sr ...
- swift language
API reference Swift UIKit Swift 菜鸟教程 Great Installed Visual Studio Code, I found I cannot open it fr ...
- NPOI 自定义单元格背景颜色-Excel
NPOI针对office2003使用HSSFWorkbook,对于offce2007及以上使用XSSFWorkbook:今天我以HSSFWorkbook自定义颜色为例说明,Office2007的未研究 ...
- Django根据现有数据库建立model
Django引入外部数据库还是比较方便的,步骤如下 创建一个项目,修改seting文件,在setting里面设置你要连接的数据库类型和连接名称,地址之类,和创建新项目的时候一致 运行下面代码可以自动生 ...
- MVC中权限管理
权限管理,一般指根据系统设置的安全规则或者安全策略,用户可以访问而且只能访问自己被授权的资源,不多不少.权限管理几乎出现在任何系统里面,只要有用户和密码的系统.权限管理还是比较复杂的,有的固定到某个模 ...
- js乱码解决方法
在开发中引用了Bootstrap多选插件,将其中显示的英文改为中文后,页面出现乱码. 对于大多数的Web页面我们一般使用俩种编码:UTF-8和GB2312,所以我们只要统一页面和JS的编码就可以避免乱 ...
- jQuery插件的开发之$.extend(),与$.fn.extend()
jQuery插件的开发包括两种: 一种是类级别的插件开发,即给jQuery添加新的全局函数,相当于给jQuery类本身添加方法.jQuery的全局函数就是属于jQuery命名空间的函数,另一种 ...
- paper 126:[转载] 机器学习中的范数规则化之(一)L0、L1与L2范数
机器学习中的范数规则化之(一)L0.L1与L2范数 zouxy09@qq.com http://blog.csdn.net/zouxy09 今天我们聊聊机器学习中出现的非常频繁的问题:过拟合与规则化. ...
- Bug修正
名称:nice! 项目名称:约跑app 组长:李权 成员:韩媛媛 刘芳芳 宫丽君 于淼 Bug修正: 1.我看到的现象:退出当前的账号后,按返回键可以再次进入登录界面. 期待的现象:能够安全登陆和退出 ...