20170831_floyd

//
//  main.cpp
//  floyd
//
//  Created by Haoying Zhao on 17/8/31.
//  Copyright © 2017年 Haoying Zhao. All rights reserved.
//

#include <iostream>
using namespace std;
#define N 6
#define MAX 32767

void print_path(int i, int j, int path[][N]) {
    if(path[i][j] == -1) {
        cout << "--->" << (char)('A'+j);
        return;
    }
    print_path(i, path[i][j],path);
    print_path(path[i][j], j,path);
}

int main(int argc, const char * argv[]) {
    int a[N][N];
    int path[N][N];
    for(int i = 0; i < N; i++)
        for(int j = 0; j < N; j++) {
            if(i != j) a[i][j] = MAX;
            else a[i][j] = 0;
            path[i][j] = -1;
        }
    a[0][1] = 6; a[1][0] = 6;a[0][2] = 3; a[2][0] = 3;
    a[1][2] = 2; a[2][1] = 2;a[1][3] = 5; a[3][1] = 5;
    a[2][3] = 3; a[3][2] = 3;a[2][4] = 4; a[4][2] = 4;
    a[3][5] = 3; a[5][3] = 3;a[3][4] = 2; a[4][3] = 2;
    a[4][5] = 5; a[5][4] = 5;
    for(int k = 0; k < N; k++)
        for(int i = 0; i < N; i++)
            for(int j = 0; j < N; j++) {
                if(a[i][j] > a[i][k] + a[k][j]) {
                    a[i][j] = a[i][k] + a[k][j];
                    path[i][j] = k;
                }
            }
    for(int i = 0; i < N; i++) {
        for(int j = 0; j < N; j++) {
            cout << a[i][j] << " ";
        }
        cout << endl;
    }
    for(int i = 0; i < N; i++)
        for(int j = 0; j < N; j++) {
            if(i == j)
                continue;
            cout << (char)('A'+i);
            print_path(i,j,path);
            cout << endl;
        }
    return 0;
}

输出:

0 5 3 6 7 9 
5 0 2 5 6 8 
3 2 0 3 4 6 
6 5 3 0 2 3 
7 6 4 2 0 5 
9 8 6 3 5 0 
A--->C--->B
A--->C
A--->C--->D
A--->C--->E
A--->C--->D--->F
B--->C--->A
B--->C
B--->D
B--->C--->E
B--->D--->F
C--->A
C--->B
C--->D
C--->E
C--->D--->F
D--->C--->A
D--->B
D--->C
D--->E
D--->F
E--->C--->A
E--->C--->B
E--->C
E--->D
E--->F
F--->D--->C--->A
F--->D--->B
F--->D--->C
F--->D
F--->E

反思:
1、二维数组传参时形参如果是二次指针则应先转换再使用,否则至少给出数组宽度。
2、输出路径使用递归,第一个节点打出,然后二分实现尾部打完,头部空缺。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 把《C++ Primer》[https://book.douban.com/subject/25708312...
    尤汐Yogy阅读 13,149评论 1 51
  • 指针是C语言中广泛使用的一种数据类型。 运用指针编程是C语言最主要的风格之一。利用指针变量可以表示各种数据结构; ...
    朱森阅读 8,814评论 3 44
  • 一、 C/C++程序基础 面试例题1——分析代码写输出(一般赋值语句的概念和方法)。 面试例题2—...
    LuckTime阅读 6,133评论 2 42
  • 阿杰终于跟他女朋友丹丹分手了。我们不知道该祝福他,还是该表示惋惜。 阿杰很帅,很优秀,工作努力,小有积蓄,已经靠自...
    游走星宿阅读 2,854评论 1 2
  • 文:@-情人醫生- 在开始码这些文字的时候我还不知道自己要讲什么,脑海里一片空白,又什么乱七八糟的都有。现在的我刚...
    情人醫生阅读 2,649评论 0 0