转载 最佳路径的算法

          目的:从如下所示的图中,用程序找出从A到D所花时间

 

#define  NODENUM 6
#define  STARTNODE 0
#define  TRAGETNODE 3
    
char  g_aNodes[NODENUM] = {'A','B','C','D','E','F'} ;
int  g_aDist[NODENUM][NODENUM] = {
    
{0,7,0,0,0,6},
    
{7,0,7,0,0,6},
    
{0,7,0,3,3,9},
    
{0,0,3,0,4,0},
    
{0,0,3,4,0,8},
    
{6,6,9,0,8,0}}
;
    
float  g_aBroken[NODENUM][NODENUM] = {
    
{0,0.7,0,0,0,0},
    
{0.7,0,0,0,0,0},
    
{0,0,0,0,0,0},
    
{0,0,0,0,0,0},
    
{0,0,0,0,0,0.6},
    
{0,0,0,0,0.6,0}}
;
    
int  g_iPath[NODENUM + 1 ];

int  searchPath( const   int  aDistMatrix[NODENUM][NODENUM], int  aPathStack[NODENUM + 1 ], const   int  iPathDist, const   float  fPassed, const   int  iCurrNode, int  iStackPoint) {
    
int i=0,j=0,r=0;
    
for(i=0;i<iStackPoint;i++){
        
if(iCurrNode==aPathStack[i])
        
{return 0;}
        
//return 0 if current node had passed
    }

    
    aPathStack[iStackPoint
++]=iCurrNode;
    
//push current node into path stack
        
    
for(i=0;i<NODENUM;i++){
        
if(aDistMatrix[iCurrNode][i]>0){
            
if(TRAGETNODE==i){
                
//find a path to target
                printf("%3d:%1.2f:",iPathDist+aDistMatrix[iCurrNode][i],fPassed*(1-g_aBroken[iCurrNode][i]));
                
for(j=0;j<iStackPoint;j++)
                    
{printf("%c->",g_aNodes[aPathStack[j]]);}
                    printf(
"%c ",g_aNodes[TRAGETNODE]);
                    r
++;
            }

            
else
            
{//find a continue
                r+=searchPath(aDistMatrix,aPathStack,iPathDist+aDistMatrix[iCurrNode][i],fPassed*(1-g_aBroken[iCurrNode][i]),i,iStackPoint);
            }

            }

    }

    
return r;
}


int  main( int  argc, char *  argv[]) {
    
int iPN=0;
    printf(
"----------------------------------------------------- ");
    iPN
=searchPath(g_aDist,g_iPath,0,1,0,0);
    printf(
"----------------------------------------------------- Found Paths:%d",iPN);
    
    
return 0;
}

 程序运行输出结果图

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值