// #include <algorithm>
// using namespace std;
#include <stdio.h>

extern "C" {
    void create_short_path(double*** M, int* n, int layer, int nfull, double** dp) {
        // 检查所有参数
        for (int i=0; i<layer; ++i) {
            printf("n[2*%d] = %d\n", i, n[2*i]);
        }
        // for (int i=0; i<layer; ++i) {
        //     for (int j=0; j<n[2*i]; ++j) {
        //         for (int k=0; k<n[2*i]; ++k) {
        //             printf("M[%d][%d][%d] = %f", i, j, k, M[i][j][k]);
        //         }
        //         printf("\n");
        //     }
        // }
        float** mem;
        mem = new float* [n[2*0]];
        // 初始化, dp[:n[2*0], :n[2*1]] <- M[0][:n[2*0], :n[2*1]]
        for (int i=0; i<n[2*0]; ++i) {
            mem[i] = new float[nfull];
            for (int j=0; j<n[2*1]; ++j) {
                dp[i][j] = M[0][i][j];
                mem[i][j] = M[0][i][j];
            }
        }
        // 递推, 针对每层
        for (int l=2; l<layer; ++l) {
            // 针对每个出发点
            for (int s=0; s<n[2*0]; ++s) {
                // 到每个终点
                for (int t=0; t<n[2*l]; ++t) {
                    // 遍历每个中间点
                    dp[s][t] = 1e9;
                    for (int mid=0; mid<n[2*(l-1)]; ++mid) {
                        if (dp[s][t] > mem[s][mid] + M[l-1][mid][t]) {
                            dp[s][t] = mem[s][mid] + M[l-1][mid][t];
                        }
                    }
                }
            }
            // 更新mem
            for (int i=0; i<n[2*0]; ++i) {
                for (int j=0; j<n[2*l]; ++j) {
                    mem[i][j] = dp[i][j];
                }
            }
        }
        // 释放
        for (int i=0; i<n[2*0]; ++i) {
            delete[] mem[i];
        }
        delete[] mem;
    }
}