热心网友* 2021-11-30 10:37 采纳率: 80%
浏览 49
已结题

弗洛伊德算法求多源最短路径

img

img

img

  • 写回答

2条回答 默认 最新

  • qq_44185869 2021-11-30 10:56
    关注

    #include<bits/stdc++.h>
    using namespace std;
    char a[1005],b[1005],e,f;
    int n,d[27][27],s=0;
    int main(){
    cin>>a>>b;
    cin>>n;
    for(int i=0;i<n;i++){
    cin>>e>>f;
    d[e-'a'][f-'a']=d[f-'a'][e-'a']=1;
    }
    for(int k=0;k<27;k++){
    for(int i=0;i<27;i++){
    for(int j=0;j<27;j++){
    if(d[i][k]!=0&&d[k][j]!=0&&i!=j){
    if(d[i][j]==0) d[i][j]=d[i][k]+d[k][j];
    else d[i][j]=min(d[i][j],d[i][k]+d[k][j]);
    }
    }
    }
    }
    for(int i=0;i<strlen(a);i++){
    s+=d[a[i]-'a'][b[i]-'a'];
    }
    cout<<s;
    return 0;
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 11月30日
  • 已采纳回答 11月30日
  • 创建了问题 11月30日

悬赏问题

  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作