[最短路Floyd],启动!!!

B3647 【模板】Floyd

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
#define fi first
#define se second
#define pb push_back
#define PII pair<int,int >
#define IOS ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
using namespace std;
const int N = 405;
int n,m;
int dis[N][N];
void floyd()
{
	for(int k=1;k<=n;k++)
	{
		for(int i=1;i<=n;i++)
		{
			for(int j=1;j<=n;j++)
			{
				dis[i][j] = min(dis[i][j],dis[i][k]+dis[k][j]);
			}
		}
	}
}
int main()
{
	IOS;
	cin>>n>>m;
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		{
			dis[i][j] = 1e9;
			if(i==j) dis[i][j] = 0;
		}
	}
	while(m--)
	{
		int a,b,w;
		cin>>a>>b>>w;
		dis[a][b] = min(dis[a][b],w);
		dis[b][a] = min(dis[b][a],w);//双向边
	}
	floyd(); 
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		{
			cout<<dis[i][j]<<" ";
		}
		cout<<"\n";
	}
}

P1744 采购特价商品

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
#define fi first
#define se second
#define pb push_back
#define PII pair<int,int >
#define IOS ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
using namespace std;
const int N = 300;
int n,m;
double dis[300][300];
struct Node{
	int x;
	int y;
}va[N];
void flyod()
{
	for(int k=1;k<=n;k++)
	{
		for(int i=1;i<=n;i++)
		{
			for(int j=1;j<=n;j++)
			{
				dis[i][j] = min(dis[i][j],dis[i][k]+dis[k][j]);
			}
		}
	}
}
int main()
{
//	IOS;
	cin>>n;
	for(int i=1;i<=n;i++) cin>>va[i].x>>va[i].y;
	cin>>m;
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		{
			dis[i][j] = 1e9;
			if(i==j) dis[i][j] = 0;
		}
	}
	for(int i=1;i<=m;i++)
	{
		int a,b;
		cin>>a>>b;
		double w = sqrt( (va[a].x-va[b].x)*(va[a].x-va[b].x)+(va[a].y-va[b].y)*(va[a].y-va[b].y) );
		dis[a][b] = min(dis[a][b],w);
		dis[b][a] = min(dis[b][a],w);
	}
	flyod();
	int s,t;
	cin>>s>>t;
	printf("%.2lf",dis[s][t]);
}

P2888 [USACO07NOV] Cow Hurdles S

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
#define fi first
#define se second
#define pb push_back
#define PII pair<int,int >
#define IOS ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
using namespace std;
const int N = 400;
int n,m,T;
int dis[N][N];
void floyd()
{
	for(int k=1;k<=n;k++)
	{
		for(int i=1;i<=n;i++)
		{
			for(int j=1;j<=n;j++)
			{
				dis[i][j] = min(dis[i][j],max(dis[i][k],dis[k][j]));
			}
		}
	}
}
int main()
{
	IOS;
	cin>>n>>m>>T;
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		{
			dis[i][j] = 1e9;
			if(i==j) dis[i][j] = 0;
		}	
	}
	while(m--)
	{
		int a,b,w;
		cin>>a>>b>>w;
		dis[a][b] = min(dis[a][b],w);
	}
	floyd();
	while(T--)
	{
		int a,b;
		cin>>a>>b;
		if(dis[a][b]==1e9) cout<<-1<<"\n";
		else cout<<dis[a][b]<<"\n";
	}
}

P1364 医院设置

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
#define fi first
#define se second
#define pb push_back
#define PII pair<int,int >
#define IOS ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
using namespace std;
const int N = 200;
int n;
int dis[N][N];
int va[N];
void floyd()
{
	for(int k=1;k<=n;k++)
	{
		for(int i=1;i<=n;i++)
		{
			for(int j=1;j<=n;j++)
			{
				dis[i][j] = min(dis[i][j],dis[i][k]+dis[k][j]);
			}
		}
	}
}
int main()
{
	IOS;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		{
			dis[i][j] = 1e9; 
			if(i==j) dis[i][j] =0;
		}
	}
	for(int i=1;i<=n;i++)
	{
		int a,b;
		cin>>va[i]>>a>>b;
		if(b!=0) dis[i][b] = min(dis[i][b],1),dis[b][i] =min(dis[b][i],1);
		if(a!=0) dis[i][a] = min(dis[i][a],1),dis[a][i] = min(dis[a][i],1);
	}
	floyd();
	int minn =1e9;
	for(int i=1;i<=n;i++)
	{
		int sum = 0;
		for(int j=1;j<=n;j++)
		{
			sum += dis[i][j]*va[j];
		}
		minn = min(sum,minn);
	}
	cout<<minn;
}

P1359 租用游艇

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
#define fi first
#define se second
#define pb push_back
#define PII pair<int,int >
#define IOS ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
using namespace std;
const int N = 400;
int n,m;
int dis[N][N];
void floyd()
{
	for(int k=1;k<=n;k++)
	{
		for(int i=1;i<=n;i++)
		{
			for(int j=1;j<=n;j++)
			{
				dis[i][j] = min(dis[i][j],dis[i][k]+dis[k][j]);
			}
		}
	}
}
int main()
{
	IOS;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		for(int j=1;j<=n;j++)
		{
			dis[i][j] = 1e9;
			if(i==j) dis[i][j] = 0;
		}
	}
	for(int i=1;i<=n-1;i++)
	{
		for(int j=i+1;j<=n;j++)
		{
			int w;
			cin>>w;
			dis[i][j] = min(dis[i][j],w);
		}
	}
	floyd();
	cout<<dis[1][n];
}
相关推荐
还有几根头发呀7 分钟前
深入理解C/C++内存管理:从基础到高级优化实践
c++
蒟蒻小袁38 分钟前
力扣面试150题-- 翻转二叉树
算法·leetcode·面试
养一只Trapped_beast42 分钟前
【LeetCode】删除排序数组中的重复项 II
算法·leetcode·职场和发展
矢鱼44 分钟前
单调栈所有模版(2)
算法
轮到我狗叫了1 小时前
力扣智慧思想小题,目录力扣.跳跃游戏(思想很重要)力扣.跳跃游戏II(还是思想)力扣.分发糖果力扣151.反转字符串中的单词力扣.轮转数组
数据结构·算法·leetcode
zxctsclrjjjcph1 小时前
【递归、搜索和回溯】递归、搜索和回溯介绍及递归类算法例题
开发语言·c++·算法·力扣
朱剑君1 小时前
排序算法——堆排序
算法·排序算法
某不知名網友1 小时前
linux_进程地址空间(虚拟地址空间)
java·linux·算法
hallo-ooo2 小时前
【C/C++】范围for循环
c语言·c++
bryant_meng2 小时前
【python】Calculate the Angle of a Triangle
开发语言·python·算法