吾爱破解 - LCG - LSG |安卓破解|病毒分析|www.52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 2156|回复: 0
收起左侧

[C&C++ 转载] 走迷宫P1238(深度优先搜索)

[复制链接]
KaQqi 发表于 2019-4-7 15:21
本帖最后由 KaQqi 于 2019-4-8 19:24 编辑


[C++] 纯文本查看 复制代码
#include <stdio.h>

char start[2];
char end[2];
int m,n;
int is_result = -1;

class Position
{
public:
        char is_available;
};

Position buffer[20][20];
class Route
{
public:
        char horizontal;
        char vertical;        
};
Route position_buffer[31];//用来记录路线 
int count = 0;

void input()
{        
        scanf("%d %d",&m,&n);
        for(int i = 1;i<=m;i++)//input
        {
                for(int j = 1;j<=n;j++)
                {
                        scanf("%d",&buffer[i][j].is_available);
                }
        }
        scanf("%d %d",&start[1],&start[2]);
        scanf("%d %d",&end[1],&end[2]);
}

void Output()
{
        for(int i=1;i<count;i++)
        {
                printf("(%d,%d)->",position_buffer[i].horizontal,position_buffer[i].vertical);
        }
        printf("(%d,%d)\n",end[1],end[2]);
}

int CheckRepeat(int horizontal,int vertical)//没有重复为通过返回1
{
        for(int i = 1;i<=count;i++)
        {
                if(position_buffer[i].horizontal == horizontal && position_buffer[i].vertical == vertical)
                {
                        return 0;
                } 
        }
        return 1;
} 

int Go(int horizontal,int vertical)//当前横纵坐标
{
        count ++;
        position_buffer[count].horizontal = horizontal;
        position_buffer[count].vertical = vertical;
        if(horizontal == end[1] && vertical == end[2])
        {
                position_buffer[count].horizontal = 0;
                position_buffer[count].vertical = 0;
                Output();
                count --;
                is_result = 0;
                return 0;
        }
        for(int i = 1;i<=4;i++)//i为1横着走,i为2竖着走
        {
                if(i == 4&&buffer[horizontal+1][vertical].is_available == 1&&CheckRepeat(horizontal+1,vertical))//向下 
                {
                        Go(horizontal+1,vertical);
                }
                if(i == 3&&buffer[horizontal][vertical+1].is_available == 1&&CheckRepeat(horizontal,vertical+1))//向右 
                {
                        Go(horizontal,vertical+1);
                }
                if(i==2&&buffer[horizontal-1][vertical].is_available == 1&&CheckRepeat(horizontal-1,vertical))//向上 
                {
                        Go(horizontal-1,vertical); 
                }
                if(i == 1&&buffer[horizontal][vertical-1].is_available == 1&&CheckRepeat(horizontal,vertical-1))//向左 
                {
                        Go(horizontal,vertical-1);
                }
        }
        count --;
} 


int main()
{
        input();
        Go(start[1],start[2]);
        if(is_result == -1)
        {
                printf("-1");
        }
        return 0;
}

//by KaQqi 20190407

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则 警告:本版块禁止灌水或回复与主题无关内容,违者重罚!

快速回复 收藏帖子 返回列表 搜索

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-4-28 02:55

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表