pat 1003. Emergency (25)

本文介绍了一种使用Dijkstra算法求解加权最短路径的问题,并在此基础上通过DFS算法选择权重最大的路径。详细解释了算法实现过程,包括初始化、最短路径查找和路径权重最大化的递归遍历。

链接:http://pat.zju.edu.cn/contests/pat-a-practise/1003

 

题意:计算两个点之间的加权最短路径,若有多条最短路径,选取沿途节点权重和最大的。

 

分析:利用Dijkstra算法求出最短路径,然后利用dfs遍历选取路径最短并且节点权重最大。

 

#include<stdio.h>
#include<stdlib.h>
#include<string.h>

#define Inf 100000000

int road[505][505];
int people[505];
int n, m, from, to;

int known[505];
int d[505];
int p[505];

int visited[505];
int maxNum = -1;
int pathNum = 0;

//void printStatus() {
//	int i;
//	printf("known:");
//	for (i = 0; i < n; i++) {
//		printf("%d ", known[i]);
//	}
//	printf("d:");
//	for (i = 0; i < n; i++) {
//		printf("%d ", d[i]);
//	}
//
//	printf("p:");
//	for (i = 0; i < n; i++) {
//		printf("%d ", p[i]);
//	}
//	printf("\n");
//}

int getMin() {
	int i;
	int min = Inf;
	int minIdx = -1;
	for (i = 0; i < n; i++) {
		if (!known[i] && d[i] < min) {
			min = d[i];
			minIdx = i;
		}
	}
	return minIdx;

}

void dijkstra() {
	//init
	memset(known, 0, sizeof(known));
	memset(p, -1, sizeof(p));
	int i;
	for (i = 0; i < n; i++)
		d[i] = Inf;

	d[from] = 0;
//	printStatus();
	//loop
	int min;
	while (1) {
		min = getMin();
		if (min == -1)
			break;

		known[min] = 1;
		int j;
		for (j = 0; j < n; j++) {
			if (road[min][j]) {
				if (!known[j])
					if (d[min] + road[min][j] < d[j]) {
						d[j] = d[min] + road[min][j];
						p[j] = min;
					}

			}

		}

	}

}

//void printPath(int to) {
//	if (p[to] != -1)
//		printPath(p[to]);
//	printf("%d ", to);
//}

void dfs(int city, int dis, int peoNum) {
	if (city == to && dis == d[to]) {
		pathNum++;
		if (peoNum > maxNum)
			maxNum = peoNum;
	}
	if(dis>d[to])
		return;
	int i;
	for (i = 0; i < n; i++) {
		if (road[city][i] && !visited[i]) {
			visited[i] = 1;
			dfs(i, dis + road[city][i], peoNum + people[i]);
			visited[i] = 0;
		}
	}

}

int main() {
	scanf("%d%d%d%d", &n, &m, &from, &to);
	int i;
	for (i = 0; i < n; i++)
		scanf("%d", &people[i]);
	int a, b, dis;
	for (i = 0; i < m; i++) {
		scanf("%d%d%d", &a, &b, &dis);
		road[a][b] = dis;
		road[b][a] = dis;
	}
	dijkstra();
//	printStatus();

//	printPath(to);

	dfs(from, 0, people[from]);
	printf("%d %d\n", pathNum, maxNum);

	return 0;
}

 

当前提供的引用内容并未涉及 PAT 1003 的具体描述或解决方案。然而,可以基于 PAT 题目的常见模式以及算法竞赛的知识体系来推测其可能的内容。 通常情况下,PAT(Programming Ability Test)中的题目会围绕常见的数据结构与算法展开,例如字符串处理、动态规划、图论、贪心算法等。对于 PAT 1003,虽然具体的题目尚未提供,但可以根据 PAT 考试的特点推断出一些通用的信息: ### 可能的主题范围 如果 PAT 1003 是一道典型的编程题,则它可能会涉及到以下主题之一: - **字符串操作**:如子串匹配、正则表达式应用等。 - **数组/列表操作**:查找最大值、最小值或者特定条件下的元素组合。 - **基本算法设计**:如排序、二分查找或其他基础算法的应用。 以下是针对假设场景下的一般性讨论和代码实现示例。 --- #### 假设情景一:字符串处理类问题 假如 PAT 1003 涉及到字符串的操作,比如统计字符频率并按某种规则排序输出,那么可以用如下方法解决: ```python from collections import Counter def process_string(s): count = Counter(s) # 统计每个字符出现次数 result = sorted(count.items(), key=lambda x: (-x[1], ord(x[0]))) # 排序逻辑 return ''.join([char * freq for char, freq in result]) input_str = input().strip() output_str = process_string(input_str) print(output_str) ``` 上述代码实现了对输入字符串中各字符按照频次降序排列的功能[^4]。若有相同频次,则依据 ASCII 编码顺序升序排列。 --- #### 假设情景二:简单数值计算型问题 另一种可能性是该题属于简单的数值运算范畴,例如求解一组数列的平均值及其偏差情况。 ```python import math def calculate_statistics(numbers): mean_value = sum(numbers) / len(numbers) variance = sum((num - mean_value)**2 for num in numbers) / len(numbers) std_deviation = math.sqrt(variance) return round(mean_value, 2), round(std_deviation, 2) raw_input = list(map(float, input().split())) mean, deviation = calculate_statistics(raw_input) print(f"{mean} {deviation}") ``` 此段程序能够接收一系列浮点数作为输入,并返回它们的均值与标准差结果[^5]。 --- 尽管目前无法确切得知 PAT 1003 的具体内容,但从以往经验来看,大多数此类考试都会集中考察考生的基础编码能力与逻辑思维水平。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值