【牛客网】 小白月赛16 J题 小雨坐地铁

题目链接:https://ac.nowcoder.com/acm/contest/949/J

题意:多条地铁线路,从起点到终点的最短路。

题解:使用分层图最短路。
很容易想到建 m 层图,如果多条地铁线都经过同一个点,则在这些点之间暴力两两连边,这样连边是 O(nm2),
我们可以多建一层虚点,所有点到它对应的虚点不需要代价,从虚点到它对应的点需要对应的代价,这样就可以优化到 O(nm) 建图。最后跑一边最短路就好了。

/*
时间复杂度:O(mlogn)点的数量
*/
#include<bits/stdc++.h>
using namespace std;
const int maxn = 6e5 + 10;	//最大值为结点的个数 
#define INF 2147483647
typedef long long int ll;

vector<ll> G[maxn];			//当点的数量过大时,这里有可能会内存溢出,开全局变量就行 

struct Dijkstra				//封装的Dijkstra模板
{
	struct Edge
	{
		ll from, to, dist;
		Edge(int u, int v, int d) :from(u), to(v), dist(d) {}
	};
	ll n, m, k;			//n个点,m个边 
	vector<Edge> edges;
	bool done[maxn]; 	//是否已永久标号
	ll d[maxn]; 		//s到各个点的距离
	ll p[maxn]; 		//最短路中的上一条弧
	void init(ll n) 	//初始化边和点 
	{
		this->n = n;
		for (int i = 0; i < n; i++) G[i].clear(), p[i] = 0;
		edges.clear();
	}
	void AddEdge(ll from, ll to, ll dist) //添加边 
	{
		edges.push_back(Edge(from, to, dist));
		k = edges.size();
		G[from].push_back(k - 1);
	}
	struct HeapNode 	//寻找未使用的最小d[i],把的d[i]和i绑定到一起 
	{
		ll d, u;
		bool operator < (const HeapNode& rhs) const
		{
			return d > rhs.d;
		}
	};
	void dijkstra(int s)
	{
		priority_queue<HeapNode> Q;
		for (int i = 0; i < n; i++) d[i] = INF;
		d[s] = 0;
		memset(done, 0, sizeof(done));
		Q.push((HeapNode) { 0, s });
		while (!Q.empty())
		{
			HeapNode x = Q.top(); Q.pop();
			ll u = x.u;
			if (done[u]) continue;
			done[u] = true;
			ll glen = G[u].size();
			for (int i = 0; i < glen; i++)
			{
				Edge& e = edges[G[u][i]];
				if (d[e.to] > d[u] + e.dist)
				{
					d[e.to] = d[u] + e.dist;
					p[e.to] = u;
					Q.push((HeapNode) { d[e.to], e.to });
				}
			}
		}
	}
};
int main()
{
	Dijkstra djk;
	int n, m, s, t;
	cin >> n >> m >> s >> t;
	djk.n = (m + 2)*n + 1;	//因为需要建立一层虚点,所以一共有 (m + 2)*n 个点
	djk.m = m;				//边
	djk.init(djk.n);		//清空
	for (int i = 1; i <= m; i++)
	{
		int a, b, c, lat, k;
		cin >> a >> b >> c;
		for (int j = 1; j <= c; j++)
		{
			cin >> k;
			if (j != 1)		//与上一站相连
			{
				djk.AddEdge(i*n + lat, i*n + k, b);
				djk.AddEdge(i*n + k, i*n + lat, b);
			}
			djk.AddEdge(i*n + k, n*(m + 1) + k, 0);	//与建立的虚点相连
			djk.AddEdge(n*(m + 1) + k, i*n + k, a);
			lat = k;
		}
	}
	djk.dijkstra(n*(m + 1) + s);					//最短路

	if (djk.d[n*(m + 1) + t] == INF)
		cout << -1 << endl;
	else
		cout << djk.d[n*(m + 1) + t] << endl;
	return 0;
}

 

内容概要:本文深入解析了扣子COZE AI编程及其详细应用代码案例,旨在帮助读者理解新一代低门槛智能体开发范式。文章从五个维度展开:关键概念、核心技巧、典型应用场景、详细代码案例分析以及未来发展趋势。首先介绍了扣子COZE的核心概念,如Bot、Workflow、Plugin、Memory和Knowledge。接着分享了意图识别、函数调用链、动态Prompt、渐进式发布及监控可观测等核心技巧。然后列举了企业内部智能客服、电商导购助手、教育领域AI助教和金融行业合规质检等应用场景。最后,通过构建“会议纪要智能助手”的详细代码案例,展示了从需求描述、技术方案、Workflow节点拆解到调试与上线的全过程,并展望了多智能体协作、本地私有部署、Agent2Agent协议、边缘计算插件和实时RAG等未来发展方向。; 适合人群:对AI编程感兴趣的开发者,尤其是希望快速落地AI产品的技术人员。; 使用场景及目标:①学习如何使用扣子COZE构建生产级智能体;②掌握智能体实例、自动化流程、扩展能力和知识库的使用方法;③通过实际案例理解如何实现会议纪要智能助手的功能,包括触发器设置、下载节点、LLM节点Prompt设计、Code节点处理和邮件节点配置。; 阅读建议:本文不仅提供了理论知识,还包含了详细的代码案例,建议读者结合实际业务需求进行实践,逐步掌握扣子COZE的各项功能,并关注其未来的发展趋势。
基于Django+Vue的双相情感障碍交流平台研究AI更换标第1章引言介绍双相情感障碍交流平台的背景、意义、研究现状以及论文的研究方法和创新点。1.1研究背景与意义阐述双相情感障碍交流平台的重要性和实际需求。1.2国内外研究现状分析国内外在双相情感障碍交流平台方面的研究进展。1.3研究方法与创新点介绍论文采用的研究方法和平台的创新之处。第2章相关理论技术介绍Django、Vue以及双相情感障碍相关理论知识。2.1Django框架概述简述Django框架的特点、优势及其在Web开发中的应用。2.2Vue框架概述阐述Vue框架的核心思想、特点及其在前端开发中的应用。2.3双相情感障碍理论知识介绍双相情感障碍的基本概念、症状表现及其治疗方法。第3章平台需求分析与设计详细分析用户需求,设计双相情感障碍交流平台的整体架构和功能模块。3.1用户需求分析通过调研了解用户需求,为平台设计提供参考。3.2平台整体架构设计根据用户需求,设计平台的整体架构和技术路线。3.3功能模块设计详细介绍平台各个功能模块的设计思路和实现方法。第4章平台实现与测试阐述双相情感障碍交流平台的实现过程,包括前端和后端的实现,以及平台的测试。4.1前端实现利用Vue框架实现平台的前端界面和交互功能。4.2后端实现采用Django框架实现平台的后端逻辑和数据处理功能。4.3平台测试与优化对平台进行全面测试,发现并解决潜在问,优化平台性能。第5章平台应用与评价将双相情感障碍交流平台应用于实际场景,并对其进行综合评价。5.1平台应用情况介绍平台在实际应用中的情况,包括用户反馈和使用效果。5.2平台评价指标与方法确定平台的评价指标和方法,对平台进行全面评估。5.3评价结果与分析根据评价指标和方法,得出平台的评价结果,并进行详细分析。第6章结论与展望总结论文的研究成果,分析双相情感障碍交流平台的优缺点,并展望未来的研
资源下载链接为: https://pan.quark.cn/s/1bfadf00ae14 安捷伦IO Libraries Suite 15.5是由安捷伦科技公司推出的一款专业软件工具,广泛应用于科学研究、工程开发和数据采集等领域。该版本专为Windows XP系统设计,旨在满足仍在使用XP系统的用户需求。以下是该套件的主要功能、使用场景及研究开发应用的详细介绍。 仪器控制:该套件的核心功能是通过GPIB、USB、以太网等多种接口,实现对安捷伦品牌仪器设备(如示波器、逻辑分析仪、频谱分析仪等)的远程操作。 驱动程序支持:包含大量驱动程序,覆盖安捷伦广泛的硬件产品线,确保用户能轻松与不同仪器通信。 数据采集与处理:提供数据采集工具,支持实时数据获取、存储和分析,便于用户管理实验数据。 编程接口:支持VISA、Visual Basic、C++、LabVIEW等多种编程语言,允许用户自定义仪器控制逻辑,实现自动化测试和测量。 教育实验室:在高校物理、电子、通信等实验室,该套件可帮助学生高效进行实验操作。 产品研发:工程师在产品开发阶段,可利用该套件快速验证原型,测试性能指标。 生产测试:在生产线上,可通过自动化脚本控制多台仪器进行批量测试,提高生产效率。 信号分析:在电子工程领域,该套件可与安捷伦频谱分析仪配合,进行复杂信号分析和频谱监测。 嵌入式系统测试:在嵌入式系统开发中,可用于调试硬件接口,验证系统功能。 软件定义无线电(SDR):在SDR项目中,该套件可提供实时数据采集和处理能力,用于信号接收和发送控制。 该版本虽然专为Windows XP设计,但随着操作系统的发展,用户可能需要升级到更高版本以适应新环境。需要注意的是,部分较新的安捷伦仪器可能不再支持XP系统,因此在选择仪器时需谨慎。尽管如此,安捷伦IO Libraries Suite 15.5仍是一个强大且全面的工具,尤
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值