(重刷)HDU 1874 畅通工程续 + HDU 2544 最短路 最短路水题,dijkstra解法。

本文通过两道题目介绍了Dijkstra算法的应用实例。首先介绍了算法的基本实现思路,并提供了完整的代码实现,随后通过具体题目展示了如何利用Dijkstra算法求解最短路径问题。

floyd解法

今天初看dijkstra,先拿这两题练手,其他变形题还是不是很懂。

模版题,纯练打字。。。

HDU 1874:


#include <cstdio>

#define MAXN 200
#define INF 0xfffff 

int n;
int Edge[MAXN][MAXN];
int s[MAXN];
int dist[MAXN];
int path[MAXN];

void Dijkstra(int v0) {
	int i, j, k;
	for (i = 0; i < n; i++) {
		dist[i] = Edge[v0][i];
		s[i] = 0;
		if (i != v0 && INF > dist[i])
			path[i] = v0;
		else
			path[i] = -1;
	}
	s[v0] = 1;
	dist[v0] = 0;
	for (i = 0; i < n - 1; i++) {
		int min = INF, u = v0;
		for (j = 0; j < n; j++)
			if (!s[j] && dist[j] < min){
				u = j;
				min = dist[j];
			}//if
		s[u] = 1;
		for (k = 0; k < n; k++) {
			if (!s[k] && Edge[u][k] < INF && dist[u] + Edge[u] [k] < dist[k]) {
				dist[k] = dist[u] + Edge[u][k];
				path[k] = u;
			}//if
		}//for
	}//for
}

int main() {
	int m;
	int i, j;
	while (scanf("%d%d", &n, &m) != EOF) {
		for (i = 0; i < n; i++)
			for (j = 0; j < n; j++)
				if (i == j)
					Edge[i][j] = 0;
				else
					Edge[i][j] = INF;
		int x, y, z;
		for (i = 0; i < m; i++) {
			scanf("%d%d%d", &x, &y, &z);
			if (z < Edge[x][y])
				Edge[y][x] = Edge[x][y] = z;
		}
		scanf("%d%d", &x, &y);
		Dijkstra(x);
		if (dist[y] < INF)
			printf("%d\n", dist[y]);
		else
			printf("-1\n");
	}//while
	return 0;
}


HDU 2544:

#include <cstdio>

#define MAXN 200
#define INF 0xfffff 

int n;
int Edge[MAXN][MAXN];
int s[MAXN];
int dist[MAXN];
int path[MAXN];

void Dijkstra(int v0) {
	int i, j, k;
	for (i = 0; i < n; i++) {
		dist[i] = Edge[v0][i];
		s[i] = 0;
		if (i != v0 && INF > dist[i])
			path[i] = v0;
		else
			path[i] = -1;
	}
	s[v0] = 1;
	dist[v0] = 0;
	for (i = 0; i < n - 1; i++) {
		int min = INF, u = v0;
		for (j = 0; j < n; j++)
			if (!s[j] && dist[j] < min){
				u = j;
				min = dist[j];
			}//if
		s[u] = 1;
		for (k = 0; k < n; k++) {
			if (!s[k] && Edge[u][k] < INF && dist[u] + Edge[u] [k] < dist[k]) {
				dist[k] = dist[u] + Edge[u][k];
				path[k] = u;
			}//if
		}//for
	}//for
}

int main() {
	int m;
	int i, j;
	while (scanf("%d%d", &n, &m) && n && m) {
		for (i = 0; i < n; i++)
			for (j = 0; j < n; j++)
				if (i == j)
					Edge[i][j] = 0;
				else
					Edge[i][j] = INF;
		int x, y, z;
		for (i = 0; i < m; i++) {
			scanf("%d%d%d", &x, &y, &z);
			if (z < Edge[x-1][y-1])
				Edge[y-1][x-1] = Edge[x-1][y-1] = z;
		}
		Dijkstra(0);
		printf("%d\n", dist[n - 1]);
	}//while
	return 0;
}




本数据集来源于 2024 年 7 月在江西省中东部余干县、贵溪市、金溪县丘陵林地采集的千枚岩、红砂岩、花岗岩母质发育红壤关键带剖面土壤实测数据,空间覆盖 3 个县域不同岩性风化壳林地,采样点位经纬度分别为千枚岩剖面 P10(116.8316°E,28.5269°N)、红砂岩剖面 P08(117.1048°E,28.3492°N)、花岗岩剖面 P04(116.6883°E,27.9963°N);垂直空间采样深度存在差异,千枚岩与花岗岩剖面采样深度 0~600 cm,红砂岩剖面采样深度 0~450 cm,垂直分层采样分辨率为 0~50 cm 区间分 0~20 cm、20~50 cm 两层,50 cm 以下土层以 50 cm 为固定间隔分层,整套数据集共包含 36 条土壤剖面分层记录,其中 P10 千枚岩剖面 13 条、P08 红砂岩剖面 11 条、P04 花岗岩剖面 13 条。数据采集时间为 2024 年 7 月,实验室理化指标、矿物测试、酸碱滴定及统计建模工作于 2024 年 7 月 —2026 年 5 月完成,无时间序列连监测数据,仅为单次野外剖面采样静态数据集。 数据集包含野外剖面基础信息、土壤酸碱滴定原始数据、土壤酸度指标、交换性盐基与交换性酸、土壤机械组成、有机质、黏土与原生矿物半定量 XRD 数据、无定形 / 晶形铁铝氧化物含量。全量理化指标计量单位统一规范:酸缓冲容量 pHBC 单位为 cmol・kg⁻¹・pH⁻¹,交换性酸、交换性盐基离子单位为 cmol・kg⁻¹,矿物以质量百分比(%)表示,、黏粒 / 粉粒 / 砂粒、有机质、铁铝氧化物单位均为g/kg,pH 为无量纲数值。 覆盖范围: 中位纬度: 28.2616 中位经度: 116.89654999999999 南界纬度: 27.9963 西界经度: 116.6883 北界纬度: 28.5269 东界经
【内容概要】 基于 Vite 6 与 TypeScript 5 严格模式构建的企业级前端工程化脚手架模板,开箱集成代码规范、单元测试、持集成与容器化部署的完整链路。模板将 ESLint 9 扁平化配置、typescript-eslint 类型感知规则、Prettier 3 格式化、Vitest 2 单元测试(含 V8 覆盖率 80% 阈值)、Husky v9 + lint-staged 提交前钩子,以及 GitHub Actions 多版本 Node 矩阵流线打通到位,另附多阶段 Dockerfile 与 nginx 静态托管配置,可在本地 pnpm install 或 docker compose up 直接启动。源码层面提供分级日志器 Logger、强类型事件总线 EventBus(基于 mitt)、Rust 风格 Result 类型、数字与字节时长格式化工具、可复用 Counter 组件等示例,并配套 32 个 Vitest 用例,演示如何在严格类型约束下编写可测试、可维护的工程化代码。 【适合人群】 1. 准备搭建中大型前端项目,需要一份可直接落地的工程化基线模板的全栈工程师; 2. 希望系统理解 Vite 构建配置、ESLint 9 扁平配置、Vitest 覆盖率门槛与 GitHub Actions 流线如何串联的中级前端开发者; 3. 在团队中负责制定前端规范、CI 流程与 Docker 部署方案的技术负责人; 4. 学习 TypeScript 严格模式下编写类型安全工具库、组件、事件系统的实战示范的学习者。 【能学到什么】 1. Vite 6 + TypeScript 5 严格模式(strict、noUncheckedIndexedAccess、exactOptionalPropertyTypes)下的工程结构组织方式; 2. ESLint 9 Fl
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值