热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

POJ2263:HeavyCargo最大载重问题

POJ2263是一个经典的图论问题,涉及寻找从起点到终点的最大载重路径。本文将详细介绍该问题的背景、解题思路及代码实现。

题目链接:http://poj.org/problem?id=2263

问题描述:给定一个无向图,每条边有一个最大载重量。求从起点到终点的最大载重路径。

#include
#include
#include
#include
#include
#define N 202
using namespace std;

int gra[N][N], dis[N], vis[N], n;

void dijkstra(int beg, int end) {
    int i, j, k, temp, m;
    for (i = 1; i <= n; i++) {
        dis[i] = gra[beg][i];
        vis[i] = false;
    }
    vis[beg] = true;
    for (i = 2; i <= n; i++) {
        k = 0;
        temp = 0;
        for (j = 1; j <= n; j++) {
            if (!vis[j] && dis[j] > temp) {
                temp = dis[j];
                k = j;
            }
        }
        if (k == end) {
            printf("%d tons\n", temp);
            return;
        }
        vis[k] = true;
        for (j = 1; j <= n; j++) {
            if (!vis[j]) {
                m = min(temp, gra[k][j]);
                if (m > dis[j])
                    dis[j] = m;
            }
        }
    }
}

int main() {
    int i, j, k, m, h, count = 1;
    string s1, s2;
    map mp;
    while (scanf("%d%d", &n, &m), n || m) {
        k = 1;
        for (i = 1; i <= n; i++)
            for (j = 1; j <= n; j++)
                gra[i][j] = 0;
        while (m--) {
            cin >> s1 >> s2 >> h;
            if (mp.find(s1) == mp.end())
                mp[s1] = k++;
            if (mp.find(s2) == mp.end())
                mp[s2] = k++;
            i = mp[s1];
            j = mp[s2];
            if (h > gra[i][j])
                gra[i][j] = gra[j][i] = h;
        }
        cin >> s1 >> s2;
        printf("Scenario #%d\n", count++);
        dijkstra(mp[s1], mp[s2]);
        printf("\n");
    }
    return 0;
}

参考链接:https://www.cnblogs.com/YogurtShen/archive/2012/08/30/2664306.html


推荐阅读
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 深入理解Java中的volatile、内存屏障与CPU指令
    本文详细探讨了Java中volatile关键字的作用机制,以及其与内存屏障和CPU指令之间的关系。通过具体示例和专业解析,帮助读者更好地理解多线程编程中的同步问题。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • Docker的安全基准
    nsitionalENhttp:www.w3.orgTRxhtml1DTDxhtml1-transitional.dtd ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文介绍了在使用Visual Studio 2015进行项目开发时,遇到类向导弹出“异常来自 HRESULT:0x8CE0000B”错误的解决方案。通过具体步骤和实践经验,帮助开发者快速排查并解决问题。 ... [详细]
  • 本文基于刘洪波老师的《英文词根词缀精讲》,深入探讨了多个重要词根词缀的起源及其相关词汇,帮助读者更好地理解和记忆英语单词。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 如何在PHPcms网站中添加广告
    本文详细介绍了在PHPcms网站后台添加广告的方法,涵盖多种常见的广告形式,如百度广告和Google广告,并提供了相关设置的步骤。同时,文章还探讨了优化网站流量的SEO策略。 ... [详细]
author-avatar
小傲骄FMJ
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有