poj 3009 Curling 2.0
题目来源:http://poj.org/problem?id=3009
一道深搜题目,与一般搜索不同的是,目标得一直往一个方向走,直到出界或者遇到阻碍才换方向。
1 #include<iostream>
2 #include<cstdio>
3 #include<cstring>
4 #include<cstdlib>
5 #include<cmath>
6 #include<algorithm>
7 #include<queue>
8 #define inf 0x7fffffff
9 using namespace std;
10 int w,h;
11 int an[4][2]={-1,0, 1,0 ,0,-1, 0,1 };
12 int bn[25][25],vis[25][25];
13 int sx,sy,gx,gy;
14 int ans;
15 void dfs(int x,int y,int time)
16 {
17 if (time>=10) return ;
18 if (x<0 || x>=h || y<0 || y>=w) return ;
19 int ok=0;
20 int j=x,k=y;
21 int i;
22 for (i=j-1 ;i>=0 ;i--)
23 {
24 if (bn[i][k]==1) break;
25 if (bn[i][k]==3) {ans=min(ans,time+1) ;return ; }
26 }
27 if (i>=0 && i+1!=x)
28 {
29 bn[i][k]=0;
30 dfs(i+1,k,time+1);
31 bn[i][k]=1;
32 }
33 j=x ;k=y ;
34 for (i=j+1 ;i<h ;i++)
35 {
36 if (bn[i][k]==1) break;
37 if (bn[i][k]==3) {ans=min(ans,time+1) ;return ; }
38 }
39 if (i<h && i-1!=x)
40 {
41 bn[i][k]=0;
42 dfs(i-1,k,time+1);
43 bn[i][k]=1;
44 }
45 j=x ;k=y ;
46 for (i=y-1 ;i>=0 ;i--)
47 {
48 if (bn[j][i]==1) break;
49 if (bn[j][i]==3) {ans=min(ans,time+1) ;return ; }
50 }
51 if (i>=0 && i+1!=y)
52 {
53 bn[j][i]=0;
54 dfs(j,i+1,time+1);
55 bn[j][i]=1;
56 }
57 j=x ;k=y ;
58 for (i=y+1 ;i<w ;i++)
59 {
60 if (bn[j][i]==1) break;
61 if (bn[j][i]==3) {ans=min(ans,time+1) ;return ; }
62 }
63 if (i<w && i-1!=y)
64 {
65 bn[j][i]=0 ;
66 dfs(j,i-1,time+1);
67 bn[j][i]=1;
68 }
69 }
70 int main()
71 {
72 while (cin>>w>>h)
73 {
74 if (!w && !h) break;
75 for (int i=0 ;i<h ;i++)
76 {
77 for (int j=0 ;j<w ;j++)
78 {
79 scanf("%d",&bn[i][j]);
80 if (bn[i][j]==2) {sx=i ;sy=j ; }
81 if (bn[i][j]==3) {gx=i ;gy=j ; }
82 }
83 }
84 int ok=1;
85 if (sx>0 && bn[sx-1][sy]!=1) ok=0;
86 if (sx<h-1 && bn[sx+1][sy]!=1) ok=0;
87 if (sy>0 && bn[sx][sy-1]!=1) ok=0;
88 if (sy<w-1 && bn[sx][sy+1]!=1) ok=0;
89 if (ok) {cout<<-1<<endl;continue; }
90 memset(vis,0,sizeof(vis));
91 ans=inf;
92 dfs(sx,sy,0);
93 if (ans==inf) cout<<-1<<endl;
94 else cout<<ans<<endl;
95 }
96 return 0;
97 }
poj 3009 Curling 2.0的更多相关文章
- POJ 3009 Curling 2.0【带回溯DFS】
POJ 3009 题意: 给出一个w*h的地图,其中0代表空地,1代表障碍物,2代表起点,3代表终点,每次行动可以走多个方格,每次只能向附近一格不是障碍物的方向行动,直到碰到障碍物才停下来,此时障碍物 ...
- poj 3009 Curling 2.0 (dfs )
Curling 2.0 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 11879 Accepted: 5028 Desc ...
- POJ 3009 Curling 2.0(DFS + 模拟)
题目链接:http://poj.org/problem?id=3009 题意: 题目很复杂,直接抽象化解释了.给你一个w * h的矩形格子,其中有包含一个数字“2”和一个数字“3”,剩下的格子由“0” ...
- POJ 3009 Curling 2.0 {深度优先搜索}
原题 $On Planet MM-21, after their Olympic games this year, curling is getting popular. But the rules ...
- POJ 3009 Curling 2.0 回溯,dfs 难度:0
http://poj.org/problem?id=3009 如果目前起点紧挨着终点,可以直接向终点滚(终点不算障碍) #include <cstdio> #include <cst ...
- poj 3009 Curling 2.0( dfs )
题目:http://poj.org/problem?id=3009 参考博客:http://www.cnblogs.com/LK1994/ #include <iostream> #inc ...
- 【POJ】3009 Curling 2.0 ——DFS
Curling 2.0 Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 11432 Accepted: 4831 Desc ...
- 【原创】poj ----- 3009 curling 2 解题报告
题目地址: http://poj.org/problem?id=3009 题目内容: Curling 2.0 Time Limit: 1000MS Memory Limit: 65536K Tot ...
- POJ P3009 Curling 2.0 题解
深搜,向四个方向,在不越界的情况下一直闷头走,直到撞墙.到达终点就输出,没到就回溯. #include<iostream> #include<cstring> #include ...
随机推荐
- sender是什么意思C#
/// <summary> /// sender就是事件发起者,e存储事件发起者的一些参数 /// 例如: /// private void button1_Click(object se ...
- app.config *.exe.config 和*.vshost.exe.config基础学习
一.问题描述 在使用config文件来保存一些参数,便于下次启动程序时自动加载上次设置的参数的功能时, 碰到个问题,vs2010下调试运行程序始终无法实现config记录上次参数值,而直接运行exe程 ...
- jMeter 监控cpu、内存
http://jmeter-plugins.org/downloads/all/ 将JMeterPlugins.jar包复制到Jmeter的lib目录下面的ext目录下面,重新启动Jmeter,我们点 ...
- MongoDb gridfs-ngnix文件存储方案 - 图片
http://www.cnblogs.com/wintersun/p/4622205.html 在各类系统应用服务端开发中,我们经常会遇到文件存储的问题. 常见的磁盘文件系统,DBMS传统文件流存储. ...
- JS中cookie的基本使用
cookie是本身是HTML中ducument中的一个属性,可以用来保存一些简单的数据信息,比如用户名.密码等,提高一些网站的用户体验度.下面就来简单的说说cookie,它有下面几个特性: 1.有过期 ...
- JQuery遍历指定id的div name值的几种方法
JQuery遍历指定id的div name值的几种方法:方法一 $("#div1 :text").each(function () { var this_id = $(this). ...
- 第十六章 调试及安全性(In .net4.5) 之 调试程序
1. 概述 本章内容包括 如何选择合适的构建类型.创建和管理编译指令.管理程序数据文件(pdb)和指令. 2. 主要内容 2.1 构建类型 .net中默认的两种生成模式是 发布(Release)模式 ...
- win7旗舰版在安装vs2010后向sql2008添加SQL_Server_Management详解
原文地址:http://blog.csdn.net/bruce_zeng/article/details/8202746
- perl thread
#!/usr/local/bin/perl use threads; @domain = ("tom.com", "chinadns.com", "1 ...
- Python学习教程(learning Python)--3.2 if-else分支语句
if-else分支语句结构的特点是当conditon条件满足时,执行if下的语句块,当condition条件不满足时执行else下的语句块,也就是说根据条件来控制让某些语句执行,某些语句不被执行. i ...