201903CSPT5 317号子任务

news/2024/7/15 17:01:46 标签: 图论, 算法

题意:有n个点,m条无向边。n个点中有一些是行星发动机点,现在要求计算出每个点最近的k个行星发动机点的最短路径之和,如果某个点能够达到的行星发动机点不足k个,则求其能到达行星发动机点的最短路径之和。

#include<bits/stdc++.h>
using namespace std;
struct Node
{
	int w;
	int v;
	Node(int w,int v):v(v),w(w){}
};
struct node
{
	int u;
	int d;
	bool operator <(const node y) const
	{
		return d>y.d;
	}
};
vector <Node> V[10010];
vector <int> planet;
int dis[10010],vis[10010],qdis[10010];
int planetdis[10010][10010];
int n,m,k,ans=0;
void Dij(int s)
{
	for(int i=1;i<=n;i++)dis[i]=1999999999;
	dis[s]=0;
	priority_queue <node> q;
	node t;t.d=0;t.u=s;q.push(t);
	while(q.size()!=0)
	{
		int x=q.top().u;//cout<<x<<" "<<endl;
		q.pop();
		if(vis[x]==1)continue;
		vis[x]=1;
		for(int i=0;i<V[x].size();i++)
		{
			int y=V[x][i].v;int w=V[x][i].w;
			if(dis[y]>dis[x]+w)
			{
				dis[y]=dis[x]+w;
				node temp;temp.d=dis[y];temp.u=y;
				q.push(temp);
			}
		}
	}
}
int main()
{
	cin>>n>>m>>k;
	for(int i=1;i<=n;i++)
	{
		int id;
		cin>>id;
		if(id==1)planet.push_back(i);
	}
	for(int i=1;i<=m;i++)
	{
		int u,v,w;
		cin>>u>>v>>w;
		V[u].push_back(Node(w,v));
		V[v].push_back(Node(w,u));
	}
	for(int i=0;i<planet.size();i++)
	{
		memset(vis,0,sizeof(vis));
		Dij(planet[i]);
		for(int j=1;j<=n;j++)
		planetdis[i+1][j]=dis[j];
	}
	/*for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		cout<<planetdis[i][j]<<" ";
		cout<<endl;
	}*/
	vector<int> q;
	for(int i=1;i<=n;i++)
	{
		ans=0;int num=0;
		memset(qdis,0,sizeof(qdis));
		for(int j=1;j<=planet.size();j++)
		if(planetdis[j][i]!=1999999999)qdis[++num]=planetdis[j][i];
		sort(qdis+1,qdis+num+1);      //for(int l=1;l<=num;l++)cout<<qdis[l]<<" ";
		if(num<=k)
		{
			for(int j=1;j<=num;j++)
			ans+=qdis[j];
		}
		else 
		{
			for(int j=1;j<=k;j++)
			ans+=qdis[j];	
		}
		cout<<ans<<endl;
	}
	return 0;
}

http://www.niftyadmin.cn/n/5344259.html

相关文章

编写Bash脚本程序从记录文件中提取history命令的优化,再介绍linux bash语法和结构

目 录 一、引言 二、脚本代码实现 三、bash语法和结构 &#xff08;一&#xff09;基本语法 1、脚本开始与结束 2、注释 3、变量 4、数据类型 5、控制结构 6、循环控制 7、函数 8、算术运算 9、算术操作符和逻辑操作符 &#xff08;二&#xff09;命令相关…

如何使用宝塔面板配置Nginx反向代理WebSocket(wss)

本章教程&#xff0c;主要介绍一下在宝塔面板中如何配置websocket wss的具体过程。 目录 一、添加站点 二、申请证书 三、配置代理 1、增加配置内容 2、代理配置内容 三、注意事项 一、添加站点 二、申请证书 三、配置代理 1、增加配置内容 map $http_upgrade $connection_…

caj在线转换成word怎么转?几种在线转换方法详解

caj在线转换成word怎么转&#xff1f;在日常的学习和工作中&#xff0c;我们常常会遇到各种各样的文件格式。其中&#xff0c;CAJ格式的文件因其专业性强&#xff0c;常常让许多用户感到困扰。如果你手头恰好有这种格式的文件&#xff0c;却苦于无法编辑&#xff0c;那么接下来…

架构篇21:高性能负载均衡-算法

文章目录 轮询加权轮询负载最低优先性能最优类Hash 类源地址 HashID Hash 小结 负载均衡算法数量较多&#xff0c;而且可以根据一些业务特性进行定制开发&#xff0c;抛开细节上的差异&#xff0c;根据算法期望达到的目的&#xff0c;大体上可以分为下面几类。 任务平分类&…

opencv#34 边缘检测(二)

Laplacian(拉普拉斯)算子 前面介绍的Sobel算子和Scharr算子存在的问题: 1.要分别计算两个方向&#xff08;x,y)的边缘&#xff0c;之后将两方向的边缘进行叠加。 2.边缘与方向相关性较大。当我们通过Sobel算子提取x方向检测时&#xff0c;它所能够检测到的边缘都是一个沿着y…

【Java】SpringMVC参数接收

1、接收单个参数 &#xff08;1&#xff09;直接接收参数 RequestMapping("/hello") RestController public class HelloSpring {RequestMapping("/t2")public String t2(String name){return "name" name;} } 当没有传入参数时&#xff0c;返…

C#hybridCLR热更新方案初探

前言 暂时处于初步研究状态&#xff0c;目前的框架使用还是尚少&#xff0c;本篇文章旨在同步给大家大概的使用流程和使用心得&#xff0c;在初步建立新项目时可以适当考虑。 介绍 热更新 与强制更新相对应&#xff0c;移动平台上App的可执行程序没有发生变化&#xff0c;仅…

k8s的图形化工具rancher

1、rancher&#xff1a;是一个开源的企业级多集群的k8s管理平台 2、rancher和k8s的区别 &#xff08;1&#xff09;都是为了容器的调度和编排系统 &#xff08;2&#xff09;但rancher不仅能够调度&#xff0c;还能管理k8s集群&#xff0c;自带监控&#xff08;普罗米修斯&a…