hdu 1312 C++

这篇博客介绍了如何解决hdu 1312问题,涉及使用BFS(广度优先搜索)和DFS(深度优先搜索)在长方形房间的方砖地图中,从@起点遍历所有黑色方砖而不经过#。BFS通过队列实现,标记已访问节点;DFS采用递归方式,用一维方向数组辅助完成,直到所有相邻方向都已访问。
摘要由CSDN通过智能技术生成

hdu 1312 题目

• 一个长方形的房间,铺着方砖,每块砖是 #或黑点. 。
• 一个人站在黑砖上,可以按上、下、左、右方向移动到相邻的砖。
• 他不能在#上移动,他只能在黑砖上移动。
• 起点是@,要求:遍历所有黑点。

在这里插入图片描述

BFS

  • BFS 使用队列辅助实现;节点元素包含了位置的x,y。
  • 将元素进队时将元素标记为已经访问,下次搜索时跳过。
  • 返回的是可以走的位置数目。
//ECUST luoyongjun
#include<bits/stdc++.h>

using namespace std;
char room[23][23];
int dir[4][2] = {
   
        {
   -1, 0},  //向左。左上角坐标是(0, 0)
        {
   0,  -1},  //向上
        {
   1,  0},   //向右
        {
   0,  1}    //向下
};
int Wx, Hy, num;                 //Wx行,Hy列。用num统计可走的位置有多少
#define CHECK(x, y) (x<Wx && x>=0 && y >=0 && y<Hy) //是否在room里
struct node {
   
    int x, y;
};

void BFS(int dx, int dy) {
   
    num = 1;                         //起点也包含在砖块内
    queue<node> q;              //队列中放坐标点
    node start, next;
    start.x = dx;
    start.y = dy;
    q.push(start);
    while (!q.empty(
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值