1087 All Roads Lead to Rome (30

2019-01-27  本文已影响0人  我非神灵
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<vector>
#include<string>
#include<map>
using namespace std;

const int MAXV = 210;
const int INF = 1000000000;

int n, m, st = 0, G[MAXV][MAXV], weight[MAXV];
int d[MAXV], numPath = 0, maxW = 0;
double maxAvg = 0;
bool vis[MAXV];
vector<int> pre[MAXV];
vector<int> tempPath, path;
map<string, int> city2index;
map<int, string> index2city;

void Dijkstra(int s)//s 为源点
{
    fill(d, d + MAXV, INF);
    d[s] = 0;
    for (int i = 0; i < n; i++)//外层循环次数确保正确
    {
        //取V-S集合的最小距离点
        int u = -1, min = INF;
        for (int j = 0; j < n; j++)
        {
            if (vis[j] == false && d[j] < min)
            {
                min = d[j];
                u = j;
            }
        }
        if (u == -1) return;//s与剩余节点不连通
        vis[u] = true;
        for (int v = 0; v < n; v++)
        {
            if (vis[v] == false && G[u][v] != INF)
            {
                if (d[u] + G[u][v] < d[v])
                {
                    d[v] = d[u] + G[u][v];
                    pre[v].clear();
                    pre[v].push_back(u);
                }
                else if (d[u] + G[u][v] == d[v])
                {
                    pre[v].push_back(u);
                }
            }
        }
    }
}
void DFS(int v)
{
    if (v == st)
    {
        numPath++;//叶子节点数即路径数
        tempPath.push_back(v);
        double tempAvg = 0;
        int tempWeight = 0;
        for (int i = 0; i < tempPath.size(); i++)
        {
            tempWeight += weight[tempPath[i]];
        }
        tempAvg = tempWeight * 1.0 / (tempPath.size() - 1);
        if (tempWeight > maxW)
        {
            maxW = tempWeight;
            maxAvg = tempAvg;
            path = tempPath;
        }
        else if (tempWeight == maxW && tempAvg > maxAvg)
        {
            maxAvg = tempAvg;
            path = tempPath;
        }
        tempPath.pop_back();
        return;
    }
    tempPath.push_back(v);
    for (int i = 0; i < pre[v].size(); i++)
    {
        DFS(pre[v][i]);
    }
    tempPath.pop_back();
}
int main()  
{
    fill(G[0], G[0] + MAXV * MAXV, INF);
    scanf("%d%d", &n, &m);
    string city;
    cin >> city;
    city2index[city] = 0;
    index2city[0] = city;
    for (int i = 1; i < n; i++)
    {
        cin >> city >> weight[i];
        city2index[city] = i;
        index2city[i] = city;
    }
    string start, dest;
    for (int i = 0; i < m; i++)
    {
        cin >> start >> dest;
        cin >> G[city2index[start]][city2index[dest]];
        G[city2index[dest]][city2index[start]] = G[city2index[start]][city2index[dest]];
    }
    Dijkstra(0);//单源
    DFS(city2index["ROM"]);
    cout << numPath << ' ' << d[city2index["ROM"]] << ' ' << maxW << ' ' << int(maxAvg) << endl;
    for (int i = path.size() - 1; i >= 0; i--)
    {
        cout << index2city[path[i]];
        if(i!=0)
            cout << "->";
    }
    system("pause");
    return 0;
}
上一篇 下一篇

猜你喜欢

热点阅读