走迷宫sdut1269(附带dfs求所有路径与bfs求最佳路径)

记录这道题的原因是这个题的解法是一个很好的模板,特别是用数组表示方向,然后用循环进行操作,节省了不少代码量,比我之前的方法不知道高到哪里去了(噗噗噗),迷宫的问题好多可以在这基础上进行更改,值得记录。
Problem Description

有一个m*n格的迷宫(表示有m行、n列),其中有可走的也有不可走的,如果用1表示可以走,0表示不可以走,输入这m*n个数据和起始点、结束点(起始点和结束点都是用两个数据来描述的,分别表示这个点的行号和列号)。现在要你编程找出所有可行的道路,要求所走的路中没有重复的点,走时只能是上下左右四个方向。如果一条路都不可行,则输出相应信息(用-1表示无路)。
Input

第一行是两个数m,n(1< m, n< 15),接下来是m行n列由1和0组成的数据,最后两行是起始点和结束点。
Output

所有可行的路径,输出时按照左上右下的顺序(画重点)。描述一个点时用(x,y)的形式,除开始点外,其他的都要用“->”表示。如果没有一条可行的路则输出-1。
Example Input

5 4
1 1 0 0
1 1 1 1
0 1 1 0
1 1 0 1
1 1 1 1
1 1
5 4
Example Output

(1,1)->(1,2)->(2,2)->(2,3)->(3,3)->(3,2)->(4,2)->(4,1)->(5,1)->(5,2)->(5,3)->(5,4)
(1,1)->(1,2)->(2,2)->(2,3)->(3,3)->(3,2)->(4,2)->(5,2)->(5,3)->(5,4)
(1,1)->(1,2)->(2,2)->(3,2)->(4,2)->(4,1)->(5,1)->(5,2)->(5,3)->(5,4)
(1,1)->(1,2)->(2,2)->(3,2)->(4,2)->(5,2)->(5,3)->(5,4)
(1,1)->(2,1)->(2,2)->(2,3)->(3,3)->(3,2)->(4,2)->(4,1)->(5,1)->(5,2)->(5,3)->(5,4)
(1,1)->(2,1)->(2,2)->(2,3)->(3,3)->(3,2)->(4,2)->(5,2)->(5,3)->(5,4)
(1,1)->(2,1)->(2,2)->(3,2)->(4,2)->(4,1)->(5,1)->(5,2)->(5,3)->(5,4)
(1,1)->(2,1)->(2,2)->(3,2)->(4,2)->(5,2)->(5,3)->(5,4)

#include<iostream>
#include<vector>
#include<string.h>
using namespace std;
int map[1024][1024];
int arr[1024][1024];
int lx[] = { 0,-1,0,1 };
int ly[] = { -1,0,1,0 };
struct node {
    int x; int y;
    node() {}
    node (int a,int b):x(a),y(b){}
}a,b;
vector<node>vec;
int m, n,sum=0;
void dfs(int x,int y) {
    if (x == b.x&&y == b.y) {
        int i = 0;
        for (auto iter : vec) {
            i < vec.size()-1 ?
                cout << "(" << iter.x << "," << iter.y << ")" << "->" :
                cout << "(" << iter.x << "," << iter.y << ")" << endl;
            i++;
            sum++;
        }
        return;
    }
    else {
        for (int i = 0; i < 4; i++) {
            if (x + lx[i] <= m&&x + lx[i] >= 0 && y + ly[i] <= n&&y + ly[i] >= 0
                && map[x + lx[i]][y + ly[i]] == 1 && arr[x + lx[i]][y + ly[i]] == 0) {
                arr[x + lx[i]][y + ly[i]] = 1;
                vec.push_back(node(x + lx[i], y + ly[i]));
                dfs(x + lx[i], y + ly[i]);
                vec.pop_back();
                arr[x + lx[i]][y + ly[i]] = 0;
            }
        }
    }
}
int main(void) {
    memset(arr, 0, sizeof(arr));
    memset(map, 0, sizeof(map));
    cin >> m >> n;
    for(int i=1;i<=m;i++)
        for (int j = 1; j <= n; j++) {
            cin >> map[i][j];
        }
    cin >> a.x >> a.y >> b.x >> b.y;
    vec.push_back(node(a.x, a.y));
    arr[a.x][a.y] = 1;
    dfs(a.x, a.y);if(!sum)cout << -1;
    //system("pause");
    return 0;
}

/***************************************************
User name: 
Result: Accepted
Take time: 0ms
Take Memory: 2260KB
Submit time: 
****************************************************/

/*******************我是分割线**************/

在这再写一个关于bfs求最佳路径的方法并记录路径。方法是在结构体里加入一个指向指针。

#include<iostream>
#include<queue>
#include<stack>
using namespace std;
struct node {
    int x, y;
    node *pre;
};
int flag[1024][1024];
int ma[1024][1024];
int _move[4][2] = { {0,1},{1,0} ,{0,-1}, {-1,0} };
int m,n;
void bfs() {
    queue<node*>Q;
    stack<node>vec;
    node *t=new node;
    t->x = 0, t->y = 0,t->pre=nullptr;
    Q.push(t);
    while (!Q.empty()) {
        t = Q.front(); Q.pop();
        if (t->x == m - 1 && t->y == n - 1) {
            node *h = t;
            cout << "get" << endl;
            while (h) {
                vec.push(*h);
                cout << h->x << " " << h->y << endl;
                h = h->pre;
            }
            cout << endl;
            while (!vec.empty()) {
                auto iter = vec.top();
                vec.pop();
                cout << iter.x << " " << iter.y << endl;
            }
            return;
        }
        for (int i = 0; i < 4; i++) {
            node *v=new node;
            v->x = t->x + _move[i][0];
            v->y = t->y + _move[i][1];
            if (v->x < m&&v->x >= 0 && v->y < n&&v->y >= 0
                && !flag[v->x][v->y] && ma[v->x][v->y] == 1) {
                flag[v->x][v->y] = 1;
                Q.push(v);
                v->pre = t;
            }
        }
    }
    cout << "wrong";
}
int main(void) {
    cin >> m >> n;
    for (int i = 0; i < m; i++)
        for (int j = 0; j < n; j++)
            cin >> ma[i][j];
    bfs();
    system("pause");
    return 0;
}

附上两个关于bfs的博客:
http://blog.csdn.net/raphealguo/article/details/7523411

http://blog.csdn.net/acmman/article/details/38342115

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以创建一个圆类,其中包含一个半径属性和一个计算面积的方法。具体实现如下: ```python class Circle: def __init__(self, radius): self.radius = radius def area(self): return 3.14 * self.radius ** 2 ``` 在主程序中,可以创建一个圆对象,然后调用其面积方法来计算面积: ```python c = Circle(5) # 创建半径为5的圆对象 print(c.area()) # 输出圆的面积 ``` 输出结果为78.5,即半径为5的圆的面积为78.5平方单位。 ### 回答2: 本题是要设计一个类来圆的面积。在面向对象的编程中,类是一种模板,描述了对象的属性和行为,因此需要首先确定圆所具备的属性和方法。 圆的属性为半径r,方法为圆的面积。 设计思路: 首先定义一个Circle类,其中包含半径r属性。然后定义一个圆面积的方法。根据圆的面积公式 S=πr^2 ,定义一个getArea()方法,用来计算圆的面积。 代码实现: ```python class Circle: def __init__(self, radius): # 初始化半径 self.radius = radius def getArea(self): # 计算圆面积 return 3.14 * self.radius * self.radius ``` 以上代码定义了一个Circle类,其中含有初始化半径的方法和计算圆面积的方法getArea()。 测试代码: 在主函数中创建一个Circle类的对象,调用getArea()方法来计算圆的面积并输出。 ```python if __name__ == '__main__': c = Circle(5) # 创建Circle对象,半径为5 area = c.getArea() # 计算圆的面积 print("圆的面积为:%.2f" % area) # 输出圆的面积 ``` 以上测试代码输出结果为: 圆的面积为:78.50 总结: 本题设计了一个Circle类,实现了计算圆面积的方法。在实际开发中,类中还可以添加更多的属性和方法,扩展出更加丰富的功能。 ### 回答3: 在面向对象编程中,一个圆可以被看作一个类,类中需要包含圆的半径属性和计算圆面积的方法。 首先,我们需要定义一个名为Circle的类,其中包括一个半径属性和一个计算圆面积的方法。半径属性可以在构造函数中初始化,并提供一个公开的方法,让外部可以获取半径属性的值,同时提供一个计算圆面积的公开方法。 在构造函数中,我们需要将提供的半径值存储在类的内部,使其可以在其它方法内部被调用。在计算圆的面积时,我们可以使用数学库中的Math.PI和Math.pow方法来计算半径的平方。计算方法可以被定义为公开的方法,用作外部调用获取圆面积。 同时,我们还可以定义一个静态方法,用于根据给定的半径值直接返回圆面积,这个方法可以无需创建对象实例,就可以直接使用。 下面是一个简单的圆类的代码示例: class Circle { constructor(radius) { this.radius = radius; } getRadius() { return this.radius; } getArea() { return Math.PI * Math.pow(this.radius, 2); } static getAreaForRadius(radius) { return Math.PI * Math.pow(radius, 2); } } 我们可以使用下面的代码示例来测试这个圆类的实现: const circle = new Circle(5); console.log("半径为:" + circle.getRadius()); console.log("圆的面积为:" + circle.getArea()); const area = Circle.getAreaForRadius(5); console.log("半径为 5 的圆的面积为:" + area); 需要注意的是,这里定义的方法只是简单的计算圆的面积,实际的实现应该还需要进行参数有效性检查,并抛出异常等操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值