zoukankan      html  css  js  c++  java
  • ytu 2463:给小鼠补充代码(DFS 深度优先搜索)

    2463: 给小鼠补充代码

    Time Limit: 2 Sec  Memory Limit: 64 MB
    Submit: 5  Solved: 2
    [Submit][Status][Web Board]

    Description

    小鼠a与小鼠b身处一个m×n的迷宫中,如图所示。每一个方格表示迷宫中的一个房间。这m×n个房间中有一些房间是封闭的,不允许任何人进入。在迷宫中任何位置均可沿上,下,左,右4个方向进入未封闭的房间。小鼠a位于迷宫的(p,q)方格中,它必须找出一条通向小鼠b所在的(r,s)方格的路。请帮助小鼠a找出所有通向小鼠b的最短道路。

    请编程对于给定的小鼠的迷宫,计算小鼠a通向小鼠b的所有最短道路。

    //小鼠已经编好的代码如下,你只需要帮助小鼠实现dfp()函数即可,提交时也只需要提交dfp()函数的代码,其他代码会自动添加
    //以下代码自动添加到程序开始
    #include<stdio.h>
    #include<memory.h>
    #define INF 2100000000
    #define MAX 100
    int net[MAX][MAX];
    bool isv[MAX][MAX];
    int dx[4]= {1,0,-1,0};
    int dy[4]= {0,1,0,-1};
    int count,min,ct;
    int curx,cury,endx,endy;
    int col,row,num;
    //需要帮助小鼠实现的代码
    void dfp()
    {
        ......
      return ;
    }

    //以下代码自动添加到程序末尾
    int main()
    {
        int i,x,y;
        while(scanf("%d%d%d",&row,&col,&num)!=EOF)
        {
            memset(net,0,sizeof(net));
            memset(isv,0,sizeof(isv));
            min=INF;
            count=0;
            ct=0;
            for(i=0; i<num; i++)
            {
                scanf("%d%d",&x,&y);
                isv[x][y]=true;
            }
            scanf("%d%d%d%d",&curx,&cury,&endx,&endy);
            dfp();
            if(count==0) printf("No Solution! ");
            else
            {
                printf("%d %d ",min,count);
            }
        }
        return 0;
    }

    Input

    本题有多组输入数据,你必须处理到EOF为止。 每组数据的第一行有3个正整数n,m,k,分别表示迷宫的行数,列数和封闭的房间数。接下来的k行中,每行2个正整数,表示被封闭的房间所在的行号和列号。最后的2行,每行也有2个正整数,分别表示小鼠a所处的方格(p,q)和小鼠b所处的方格(r,s)。

    Output

    对于每组数据,将计算出的小鼠a通向小鼠b的最短路长度和有多少条不同的最短路输出。每组数据输出两行,第一行是最短路长度;第2行是不同的最短路数。每组输出之间没有空行。 如果小鼠a无法通向小鼠b则输出“No Solution!”。

    Sample Input

    8 8 3 3 3 4 5 6 6 2 1 7 7

    Sample Output

    11 96

    HINT

     

    Source

     1 #include<stdio.h>
     2 #include<memory.h>
     3 #define INF 2100000000
     4 #define MAX 100
     5 int net[MAX][MAX];
     6 bool isv[MAX][MAX];
     7 int dx[4]= {1,0,-1,0};
     8 int dy[4]= {0,1,0,-1};
     9 int count,min,ct;
    10 int curx,cury,endx,endy;
    11 int col,row,num;
    12  
    13 void dfp(){
    14     if(ct>min) return;
    15     if(curx<1||cury<1||curx>col||cury>row) return ;
    16     if(curx==endx&&cury==endy){
    17         if(min>ct){
    18             count=1;
    19             min=ct;
    20         }
    21         else if(min==ct)
    22             count++;
    23         else return;
    24     }
    25     else{
    26         for(int i=0;i<=3;i++){
    27             curx+=dx[i];
    28             cury+=dy[i];
    29             ct++;
    30             if(!isv[curx][cury]){
    31                 isv[curx][cury]=true;
    32                 dfp();
    33                 isv[curx][cury]=false;
    34             }
    35             ct--;
    36             curx-=dx[i];
    37             cury-=dy[i];
    38         }
    39     }
    40     return ;
    41 }
    42  
    43  
    44 int main()
    45 {
    46     int i,x,y;
    47     while(scanf("%d%d%d",&row,&col,&num)!=EOF)
    48     {
    49         memset(net,0,sizeof(net));
    50         memset(isv,0,sizeof(isv));
    51         min=INF;
    52         count=0;
    53         ct=0;
    54         for(i=0; i<num; i++)
    55         {
    56             scanf("%d%d",&x,&y);
    57             isv[x][y]=true;
    58         }
    59         scanf("%d%d%d%d",&curx,&cury,&endx,&endy);
    60         dfp();
    61         if(count==0) printf("No Solution!
    ");
    62         else
    63         {
    64             printf("%d
    %d
    ",min,count);
    65         }
    66     }
    67     return 0;
    68 }
    69  
    70 /**************************************************************
    71     Problem: 2463
    72     User: freecode
    73     Language: C++
    74     Result: Accepted
    75     Time:4 ms
    76     Memory:852 kb
    77 ****************************************************************/

    Freecode : www.cnblogs.com/yym2013

  • 相关阅读:
    Mysql5.7 Linux安装教程
    搭建appium的android环境
    SonarQube的安装、配置与使用(windows)
    动态规划(一)——0-1背包问题
    回溯法(四)——图的m着色问题
    回溯法(三)——正则表达式匹配问题
    C++中各种基本数据类型大小一览
    回溯法(二)——0-1背包问题
    回溯法(一)——八皇后问题
    分治算法——正规归并排序中顺便计算出数组中的逆序对数
  • 原文地址:https://www.cnblogs.com/yym2013/p/3486313.html
Copyright © 2011-2022 走看看