P5839-图论-Floyd算法

在搜索中bfs只适合无权图

若是碰到有权图最简单的方法就是用邻接矩阵-二维矩阵存储每个点对之间的权重,然后用floyd

1.邻接矩阵

如果是二维输入权值的话直接append就好了

python 复制代码
ma=[]

for i in range(m):
    ma.append(list(map(int,input().split())))

点对输入情况的:

INF初始化定义没有边无法到达

然后对每个点到自己定义为0,也就是没距离

同时用min读入来处理重边(i到j不止一条路,那么优先选短的)

python 复制代码
INF=float('inf')
ma=[[INF]*n for _ in range(n)]

for i in range(n):
    ma[i][i]=0

for i in range(m):
    a,b,c=map(int,input().split())
    ma[a-1][b-1]=min(ma[a-1][b-1],c)
    ma[b-1][a-1]=min(ma[b-1][a-1],c)

2.floyd算法

本质其实是动态规划

ma数组存储的是每个点之间的直接距离,并没有考虑从中节点经过的情况

那么我们只需要再枚举在 i、j 点之间的所有可能点k,用min存储更小的途径

python 复制代码
def floyd(ma):
    for k in range(m):
        for i in range(m):
            for j in range(m):
                ma[i][j]=min(ma[i][j],ma[i][k]+ma[k][j])
    return ma

如果原来的ma数组还会用到,那么最好复制一下ma

python 复制代码
        d=[[ma[i][j] for j in range(m)] for i in range(m)]

注意:不能用dist=ma.copy()

因为二维数组的浅拷贝会导致对拷贝体做更改的时候会影响本体

python 复制代码
a=[1,2,3]
a2=a.copy()
a2.append(4)
print(a,a2)

print()

b=[[1,2],[3]]
b2=b.copy()
b2[1].append(4)
print(b,b2)

'''输出
[1,2,3] [1,2,3,4]
[[1,2],[3,4]] [[1,2],[3,4]] 
'''

P5839

P5839 [USACO19DEC] Moortal Cowmbat G - 洛谷

首先我们跑一边floyd得出最小代价

python 复制代码
INF = float('inf')

n, m, k = map(int, input().split())
s = input()
ma = [list(map(int, input().split())) for _ in range(m)]

def floyd(ma):
    d = [[ma[i][j] for j in range(m)] for i in range(m)]
    for k in range(m):
        for i in range(m):
            for j in range(m):
                d[i][j] = min(d[i][j], d[i][k] + d[k][j])
    return d

d = floyd(ma)

后面就是得规划我们该如何变我们的字符串

dp状态: F[ i ]表示到i位置全部合法的最小代价

dp转移: F[ i ]=F[ j ]+k( i,j ) 其中k( i,j )表示 i 到 j 全部改为一种颜色的最小代价,这里可以用前缀和进行预处理

python 复制代码
#前缀和
su = [[0]*(n+1) for i in range(m)]

for i in range(m):
    for j in range(1, n+1):  # 从1开始到n
        su[i][j] = su[i][j-1] + d[ord(s[j])-ord('a')][i]

f = [INF]*(n+1)
f[0] = 0
mx = [0]*m
for i in range(k, n+1):
    for col in range(m):
        mx[col] = max(mx[col], su[col][i-k]-f[i-k])
    for col in range(m):
        f[i] = min(f[i], su[col][i]-mx[col])
print(f[n])
相关推荐
机器学习之心8 分钟前
PSO-LightGBM-ABKDE粒子群算法优化轻量级梯度提升机自适应带宽核密度估计多变量回归区间预测Matlab实现
算法·matlab·回归·abkde·自适应带宽核密度估计·pso-lightgbm·粒子群算法优化轻量级梯度提升机
qq_4160187223 分钟前
分布式缓存一致性
开发语言·c++·算法
CoovallyAIHub28 分钟前
多 Agent 手术推理框架:Agent 辩论+RAG 补上手术知识,零样本超越监督基线 14.6 个百分点
算法·架构·机器人
干啥啥不行,秃头第一名31 分钟前
STL容器内部实现剖析
开发语言·c++·算法
Zarek枫煜31 分钟前
zig与c3的冒泡排序算法
算法
xiaoye-duck35 分钟前
《算法题讲解指南:动态规划算法--简单多状态dp问题》--13.删除并获得点数,14.粉刷房子
c++·算法·动态规划
老鼠只爱大米37 分钟前
LeetCode经典算法面试题 #347:前 K 个高频元素(最小堆、桶排序、快速选择等多种实现方案详解)
算法·leetcode·堆排序·java面试题·桶排序·快速选择·topk
2401_8318249638 分钟前
内存泄漏检测与防范
开发语言·c++·算法
FluxMelodySun1 小时前
机器学习(二十五) 降维:主成分分析(PCA)及特征值分解
人工智能·算法·机器学习
liuyao_xianhui1 小时前
优选算法_分治_快速排序_归并排序_C++
开发语言·数据结构·c++·算法·leetcode·排序算法·动态规划