标题:[解决]上次的那个迷宫O(N^3)算法
只看楼主
SNAKEQX
Rank: 1
等 级:新手上路
帖 子:112
专家分:3
注 册:2006-4-11
 问题点数:0 回复次数:23 
[解决]上次的那个迷宫O(N^3)算法
上次卧龙孔明给我了一个求迷宫最短步数的代码,我研究了一下,加了点注释,发出来大家看看。
这个代码的算法我看懂了,自己画了一个10*10的迷宫,在纸上画了半天,得到的结果果然是最短的。
但我真的不理解,这个算法是如何被发现的。

孔明给了我这么一句话:用很容易想到的DP就可以将复杂度搞到O(N^3)
再优化一下可是使之降到O(N^2)
对于障碍物较稀疏的迷宫问题使用dfs可以更快的出解,对于障碍物密集的迷宫问题使用bfs也可以快速出解

很容易想到。。。。。真的不容易,请高手们指点一下我(不一定要完全的答案),这个算法的思路是什么。
应该是一步一步推导出这个算法的吧。推导的过程或者起点是什么。

先谢谢大家。
2楼帖代码

[[it] 本帖最后由 SNAKEQX 于 2008-4-19 11:05 编辑 [/it]]
搜索更多相关主题的帖子: 迷宫 算法 孔明 卧龙 障碍物 
2008-04-19 09:13
SNAKEQX
Rank: 1
等 级:新手上路
帖 子:112
专家分:3
注 册:2006-4-11
得分:0 
//////////////////////////////////////////////////
// Find the shortest step number, no path to show
// left top is the end point
// right bottom is the start point
//
//           !!!!!!Warning!!!!!!
// The maze in sos.in must have an answer
// Otherwise the the prog. will always loop
//////////////////////////////////////////////////

#include<stdio.h>

int main(void)
{
    int i,j,k;
    int n;        // map matrix n*n
    int x[30][30];// max map buff 30*30
    int t,c;
    FILE *in,*out;
   
    in=fopen("sos.in","r");
    out=fopen("sos.out","w");
   
    fscanf(in,"%d",&n);// first line in sos.in to n
                       // raw data array sequence is form 1 to n
                       // but in C/C++, array index starts with 0
   
    //Ini the map from sos.in
    for(i=0;i<n;i++)
      for(j=0;j<n;j++)
      {
        fscanf(in,"%d",&x[i][j]);
        if(x[i][j]==1) x[i][j]=-1; //wall  -1
        else x[i][j]=1000;         // walk path 1000.
      }                            // why 1000? bcs 30*30==900 <1000
      
    x[0][0]=1;// set the first step number,
              // not step sequence in the maze! It's end point.
    c=n-1;    // reset the array sequence from 0 to n-1
   
    /////////////////////////////////////////////////
    //                 Algorithm:                  
    // An Iterator goes from up to down,           
    // and at the same time left to right in the maze.         
    // If the neighbor position can be walked      
    // and the {value+1} is smaller than self,     
    // set the self to {value+1} .                 
    // When the Iterator goes to the start point   
    // (x[n-1,n-1]),the value of it               
    // is the answer to the ques.  .               
    /////////////////////////////////////////////////
    while(x[c][c]==1000)
    {
      for(i=0;i<n;i++)
        for(j=0;j<n;j++)
        {
          // if not the most left, left
          if(i>0)
            if(x[i-1][j]!=-1)
              if((t=x[i-1][j]+1)<x[i][j])
                x[i][j]=t;

          // if not the most right, right
          if(i<c)
            if(x[i+1][j]!=-1)
              if((t=x[i+1][j]+1)<x[i][j])
                x[i][j]=t;

          // if not the most up, up
          if(j>0)
            if(x[i][j-1]!=-1)
              if((t=x[i][j-1]+1)<x[i][j])
                x[i][j]=t;

          // if not the most down, down
          if(j<c)
            if(x[i][j+1]!=-1)
              if((t=x[i][j+1]+1)<x[i][j])
                x[i][j]=t;
        }
    }
   
    //Output the shortest steps
    fprintf(out,"%d\n",x[c][c]);
   
    //discard opened files
    fclose(in);
    fclose(out);
   
    return 0;
}
2008-04-19 09:13
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
得分:0 
这个程序是一次模拟赛写的,当时是为了提交使用了sos.in/out,其实如果是研究问题,不需要使用文件

My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2008-04-19 09:18
雨中飛燕
Rank: 1
等 级:新手上路
帖 子:765
专家分:0
注 册:2007-10-13
得分:0 
晕。。。这个什么算法。。。。像又不像BFS。。。

" border="0" />
2008-04-19 09:20
SNAKEQX
Rank: 1
等 级:新手上路
帖 子:112
专家分:3
注 册:2006-4-11
得分:0 
这个,这个是孔明给我的啊,我看了很长时间啊。。。另外BFS是什么?
还有能不能给个思路阿。。。。。
2008-04-19 09:22
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
得分:0 
BFS是广度优先搜索

My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2008-04-19 09:26
雨中飛燕
Rank: 1
等 级:新手上路
帖 子:765
专家分:0
注 册:2007-10-13
得分:0 
这算法,没有使用队列,有很多没有必要的重复
BFS和DFS最坏复杂度都是O(x*y)
但这个明显比O(x*y)要翻了一数量级的复杂度。。。

" border="0" />
2008-04-19 09:26
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
得分:0 
DFS的复杂度不是O(X*Y)吧...

My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2008-04-19 09:33
卧龙孔明
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:59
帖 子:3872
专家分:684
注 册:2006-10-13
得分:0 
BFS也不是
这个不是单向迷宫问题

My Blog: www.aiexp.info
虽然我的路是从这里开始的,但是这里不再是乐土.感谢曾经影响过,引导过,帮助过我的董凯,飞燕,leeco,starwing,Rockcarry,soft_wind等等等等.别了,BCCN.
2008-04-19 09:35
SNAKEQX
Rank: 1
等 级:新手上路
帖 子:112
专家分:3
注 册:2006-4-11
得分:0 
一下是baidu搜到的。。。。
       广度优先搜索,即BFS(Breadth First Search),常常与深度优先搜索并列提及。这是一种相当常用的图算法,其特点是:每次搜索指定点,并将其所有未访问过的近邻加入搜索队列(而深度优先搜索则是栈),循环搜索过程直到队列为空。
        在深度优先搜索中,深度越大的结点越先得到扩展。如果把它改为深度越小的结点越先得到扩展,就是广度优先搜索法。
        常见应用:无权最短路

似乎这个迷宫问题就是无权的吧,因为只要是路就能走,可以正走也可以反走。

可是算法的本质我还是不理解。
2008-04-19 09:37



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-209882-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.613802 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved