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

SWUSTOJ#1063:带权重的有向图算法计算与分析

在SWUSTOJ#1063中,题目要求对带权重的有向图进行算法计算与分析。假设图G使用邻接矩阵存储,任务是计算图中的最大权值和最小权值,并确定对应的有向边。输入数据的第一行包含一个整数n,表示图中节点的数量。随后的输入将提供图的边及其权重信息。通过该算法,可以有效地找出图中的关键路径和最短路径,为图论问题的解决提供重要参考。

SWUSTOJ #1063 带权有向图计算

  • 题目
    • 输入
    • 输出
    • 样例输入
    • 样例输出
  • 源代码
题目

假设带权有向图G采用邻接矩阵存储,计算图的最大权值、最小权值以及对应的有向边。

输入

第一行第一个整数n表示顶点的个数(顶点编号为0到n-1),第二行表示顶点i和j,接下来是为一个n*n大小的整数矩阵,表示图的邻接关系。数字为大于0表示邻接值,-1表示不邻接,对角线为0。

输出

第一行为最大权值,第二行为有向边。第三行为最小权值,第四行为有向边。
由于OJ无法显示尖括号,所以这里用圆扩号来表示有序对。

样例输入

5
0 5 -1 23 -1
-1 0 31 56 -1
-1 -1 0 -1 -1
-1 -1 -1 0 -1
56 -1 -1 19 0

样例输出

56
(1 3)(4 0)
5
(0 1)
注意:由于显示的问题,输出数据应采用尖括号。

源代码

#include
using namespace std;
int main()
{
int count1[100][2];
int count2[100][2];
int max = 0;
int min = -1;
int k;
cin >> k;
int arr[100][100];
for (int i = 0; i < k; i++)
{
for (int j = 0; j < k; j++)
{
cin >> arr[i][j];
if (arr[i][j] >= 0&&i!=j)
{
if (min == -1)
{
min = arr[i][j];
}
else if (arr[i][j] <= min)
{
min = arr[i][j];
}
if (arr[i][j] >= max)
{
max = arr[i][j];
}
}
}
}
int m = 0;
int n = 0;
for (int i = 0; i < k; i++)
{
for (int j = 0; j < k; j++)
{
if (arr[i][j] == max)
{
count1[m][0] = i;
count1[m][1] = j;
m++;
}
if (arr[i][j] == min)
{
count2[n][0] = i;
count2[n][1] = j;
n++;
}
}
}
cout << max <<endl;
for (int i = 0; i < m; i++)
{
cout << '<' << count1[i][0]<<" "<< count1[i][1] << '>';
}
cout << endl;
cout << min << endl;
for (int i = 0; i < n; i++)
{
cout << '<' << count2[i][0]<<" " << count2[i][1] << '>';
}
return 0;
}

推荐阅读
  • 本文介绍了一个使用C++编写的算法,用于从给定的字符串中找出最长的连续重复子串。例如,对于输入字符串“ababc”,算法将返回“ab”。文中不仅提供了详细的代码实现,还分析了算法的时间和空间复杂度。 ... [详细]
  • A题简单判断#includeusingnamespacestd;typedeflonglongll;intt;intmain(){cint;whil ... [详细]
  • 0-1背包问题的两种解决方法:动态规划与回溯法
    本文探讨了0-1背包问题的两种主要解决方案——动态规划与回溯法,详细介绍了每种方法的实现逻辑、算法流程及具体示例。 ... [详细]
  • C++编程基础:探索自定义数据类型
    本文继续深入C++编程的基础知识,重点讲解自定义数据类型的概念及其应用,包括枚举类型、结构体和联合体等。 ... [详细]
  • 首先说一下,这是我在CSDN上的第一个文章,其实这个账号早在几年前就申请了,不过当时只是为了下载一个资源,而且也不怎么懂信息技术相关的领域,后来就再也没怎么动过,直到今天我才开始使用这个账号 ... [详细]
  • 本文介绍了一种利用迭代法解决特定方程问题的方法,特别是当给定函数f(x)在区间[x1, x2]内连续且f(x1)0时,存在一个x~使得f(x~)=0。通过逐步细化搜索范围,可以高效地找到方程的根。 ... [详细]
  • 本文通过具体示例探讨了在 C++ 中使用 extern "C" 的重要性及其作用,特别是如何影响编译后的对象文件中的符号名称。 ... [详细]
  • 一个产品数组拼图|集合 2 (O(1)空间) ... [详细]
  • 本文探讨了两种有效的方法来确定一组10个整数中的最大值,包括使用三目运算符和循环结构。 ... [详细]
  • 本文介绍了Windows驱动开发的基础知识,包括WDF(Windows Driver Framework)和WDK(Windows Driver Kit)的概念及其重要特性,旨在帮助开发者更好地理解和利用这些工具来简化驱动开发过程。 ... [详细]
  • 题目描述:孩子们围坐在一起,分享水果,场面温馨。然而,由于孩子们身高不同,排队时显得高低不齐。给定孩子们的身高序列,通过交换某些孩子的顺序,计算每次交换后的序列混乱度。 ... [详细]
  • 本文档提供了一个使用C语言进行字符串处理的示例,通过输入两个以加号分隔的数字字符串,并计算它们的和。 ... [详细]
  • 快速排序是基于分治策略的一种排序算法,其平均时间复杂度为O(n log n),在大多数情况下表现优于其他排序算法。本文将详细介绍快速排序的工作原理,并提供一个Java语言的具体实现。 ... [详细]
  • 程序打印菱形 ... [详细]
  • VSCode中使用Clang-Format进行C/C++代码格式化配置
    本文介绍了如何在VSCode中配置Clang-Format以实现C/C++代码的自动格式化,包括安装必要的扩展、配置文件的创建以及常用设置的解释。建议阅读官方文档以获取更多详细信息。 ... [详细]
author-avatar
烦恼的天伦之乐_456
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有