当前位置: 首页 > article >正文

算法训练营|图论第8天 拓扑排序 dijkstra

题目:

拓扑排序

题目链接:

117. 软件构建 (kamacoder.com)

代码:

#include<bits/stdc++.h>
#include<unordered_map>
using namespace std;
int main() {
	int n, m;
	cin >> n >> m;
	vector<int>inDegree(n, 0);
	unordered_map<int, vector<int>>myMap;
	vector<int>result;
	for (int i = 0; i < m; i++) {
		int s, t;
		cin >> s >> t;
		inDegree[t]++;
		myMap[s].push_back(t);
	}
	queue<int>que;
	for (int i = 0; i < n; i++) {
		if (inDegree[i] == 0) {
			que.push(i);
		}
	}
	while (!que.empty()) {
		int cur = que.front();
		que.pop();
		result.push_back(cur);
		vector<int>files = myMap[cur];
		if (files.size() != 0) {
			for (int i = 0; i < files.size(); i++) {
				inDegree[files[i]]--;
				if (inDegree[files[i]] == 0) {
					que.push(files[i]);
				}
			}
		}
	}
	if (result.size() == n) {
		for (int i = 0; i < n - 1; i++) {
			cout << result[i] << ' ';
		}
		cout << result[n - 1] << endl;
	}
	else {
		cout << -1 << endl;
	}
}

题目:

dijkstra

题目链接:

47. 参加科学大会(第六期模拟笔试) (kamacoder.com)

代码:

#include<bits/stdc++.h>
using namespace std;
int main() {
	int n, m, s, e, v;
	cin >> n >> m;
	vector<vector<int>>grid(n + 1, vector<int>(n + 1, INT_MAX));
	for (int i = 0; i < m; i++) {
		cin >> s >> e >> v;
		grid[s][e] = v;
	}
	vector<int>minDist(n + 1, INT_MAX);
	vector<bool>visited(n + 1, false);
	int start = 1;
	int end = n;
	minDist[start] = 0;
	for (int i = 1; i <= n; i++) {
		int minVal = INT_MAX;
		int cur = 1;
		for (int v = 1; v <= n; v++) {
			if (!visited[v] && minDist[v] < minVal) {
				cur = v;
				minVal = minDist[v];
			}
			visited[cur] = true;
			for (int v = 1; v <= n; v++) {
				if (!visited[v] && grid[cur][v] != INT_MAX && minDist[cur] + grid[cur][v] < minDist[v]) {
					minDist[v] = minDist[cur] + grid[cur][v];
				}
			}
		}
	}
	if (minDist[end] == INT_MAX) cout << -1 << endl;
	else {
		cout << minDist[end] << endl;
	}
}


http://www.kler.cn/a/289005.html

相关文章:

  • Mac 使用mac 原生工具将mp4视频文件提取其中的 mp3 音频文件
  • QT<30> Qt中使鼠标变为转圈忙状态
  • 第12章 系统部署
  • Python 编程入门指南(一)
  • 嵌入式硬件实战提升篇(一)-泰山派RK3566制作多功能小手机
  • Java 责任链模式 减少 if else 实战案例
  • 【笔试练习】深信服校园招聘c/c 软件开发H卷
  • 使用python导出Excel表格中的lua配置
  • 初识Linux · 有关makefile
  • 【Rust光年纪】化学计算不完全指南:Rust语言库全面解析
  • jenv 一款macos下的开源JAVA多版本环境安装管理切换工具
  • Swift concurrency 5 — async let的理解与使用
  • 聊聊随机测试和猴子测试
  • Python参数传递的艺术:解锁编程灵活性的秘密武器
  • uniapp写的一个年月日时分秒时间选择功能
  • 【数据结构初阶】——栈和队列
  • 求三元组中可能出现的最小距离
  • RabbitMQ练习(Routing)
  • 使用COAP和MQTT协议的多协议方法开发的用于机器人手术的自动医疗物联网系统
  • vue3+ts 实现模板表格文件下载~
  • pikachu文件包含漏洞靶场攻略
  • 密钥分发与公钥认证:保障网络通信的安全
  • MySQL入门学习-MySQL的连接查询
  • MySQL——事务与存储过程(二)存储过程的创建(4)光标的使用
  • 【Linux学习笔记】protobuf相关操作
  • 数仓基础(九):各大公司实时数仓实践