leetcode 2976(Floyd-Warshall 算法)

2976: 转换字符串的最小成本Ⅰ

思路:将字符转换 问题建模为图的最短路径 问题,使用 Floyd-Warshall 算法预处理所有字母对之间的最小转换成本。

  1. 问题建模
  • 将 26 个小写字母看作图中的 26 个节点
  • 每个转换规则 originali -> changedi 看作一条有向边,权重为 costi
  • 目标:找到从source中每个字符到target中对应字符的++最小++转换成本
  1. 初始化距离矩阵
  • 创建一个 26×26 的二维数组 g,存储所有字母对之间的最小转换成本
  • 对角线元素初始化为 0 (同一字符转换成本为 0)
  • 其他元素初始化为一个很大的数 INF (这里用 0x3f3f3f3f)

为什么选择 0x3f3f3f3f?

0x3f3f3f3f(十进制约1,061,109,999,即 10^9 级别)是算法竞赛中常用的"无穷大"值。

  1. 添加直接转换边
  • 遍历所有给定的转换规则
  • 对于每条规则 original[i] -> changed[i],取权重的最小值 (因为可能有重复规则)
  1. Floyd-Warshall 算法
  • 三重循环:k → i → j
  • 对于每个中间节点 k,尝试通过 k 来缩短 i 到 j 的路径
  • 核心公式:gij = min(gij, gik + gkj)
  • 算法结束后,gab 就是从字母 a 转换到字母 b 的最小成本
  1. 计算总成本
  • 遍历 source 和 target 的每个位置

  • 如果当前字符相同,跳过 (成本为 0)

  • 如果 gsource_chartarget_char == INF,说明无法转换,返回 -1

  • 否则累加最小转换成本

    class Solution {
    public:
    long long minimumCost(string source, string target, vector& original, vector& changed, vector& cost) {
    int g[26][26];
    memset(g,0x3f,sizeof(g));
    for(int i=0;i<26;i++) g[i][i]=0;
    for(int i=0;i<original.size();i++){
    int x=original[i]-'a',y=changed[i]-'a';
    g[x][y]=min(g[x][y],cost[i]);
    }
    for(int k=0;k<26;k++){
    for(int i=0;i<26;i++){
    if(g[i][k]>=0x3f3f3f3f) continue;
    for(int j=0;j<26;j++){
    g[i][j]=min(g[i][j],g[i][k]+g[k][j]);
    }
    }
    }
    long long ans=0;
    for(int i=0;i<source.size();i++){
    int a=source[i]-'a',b=target[i]-'a';
    if(g[a][b]>=0x3f3f3f3f) return -1;
    ans+=g[a][b];
    }

    复制代码
          return ans;
      }

    };

相关推荐
地平线开发者9 小时前
J6B vio scenario sample
算法
BothSavage21 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn21 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽1 天前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说2 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰2 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术2 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六2 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程