首页 > 其他 > 详细

微软第四题 给定cost能遍历的最大城市数

时间:2015-09-09 22:39:10      阅读:229      评论:0      收藏:0      [点我收藏+]

有向图中N*N矩阵 cost:M, 最多可以遍历的结点个数 例如A可以有0->1->2->0->1 代价:2+2+3+2=9<10 输出4

#include <iostream>
using namespace std;

int main(){
    int N=3;int M=10;
    int A[][3]={{0,2,3},{4,0,2},{3,4,0}};
    int last_step[3];
    int dist[3][3];

    for(int i=0;i<N;i++)
    {
        for(int j=0;j<N;j++)
        {
            dist[i][j]=A[j][i];
        }
    }
    for(int i=0;i<N;i++){last_step[i]=i;}
    int Max=0;
    for(int step=1;step-Max<=1;step++){
        for(int j=0;j<N;j++){ 
            int min=INT_MAX;int u;
            for(int m=0;m<N;m++)
            {
                if(last_step[j]!=m&&dist[m][j]<min)
                {
                    min=dist[m][j];
                    u=m;
                }
            }

            last_step[j]=u;
            for(int k=0;k<N;k++) 
            {            
                dist[k][j]=min+A[k][u];        
                if(dist[k][j]<=M)
                {Max=step;}
            }   
        }    
    }
    
    cout<<Max<<endl;
    return 0;
}

 

微软第四题 给定cost能遍历的最大城市数

原文:http://www.cnblogs.com/sylar120/p/4796191.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!