数组左上角到右下角最大值路径(动态规划)

#include 
#include 

int max(int a, int b)
{
    return (a > b) ? a : b;    
}

int main()
{
    int m = 0;
    int n = 0; // n行m列
    int i = 0;
    int j = 0;
    int **array = NULL;

    if (scanf_s("%d %d", &n, &m) == 0) {
        return -1;
    }
    /* 分配空间 */
    if ((array = (int **)malloc(n * sizeof(int *))) == NULL) {
        return -1;
    }
    for (i = 0; i < n; i++) {
        if ((array[i] = (int *)malloc(m * sizeof(int))) == NULL) {
            return -1;
        }
    }
    /* 输入 */
    for (i = 0; i < n; i++) {
        for (j = 0; j < m; j++) {
            if (scanf_s("%d", &array[i][j]) == 0) {
                return -1;
            }
        }
    }
    /* 计算 */
    for (j = 1; j < m; j++) {
        array[0][j] += array[0][j - 1];
    }
    for (i = 1; i < n; i++) {
        array[i][0] += array[i - 1][0];
    }
    for (i = 1; i < n; i++) {
        for (j = 1; j < m; j++) {
            array[i][j] += max(array[i - 1][j], array[i][j - 1]);
        }
    }
    printf("%d\n", array[n - 1][m - 1]);

    /* 释放空间 */
    for (i = 0; i < n; i++) {
        free(array[i]);
    }
    free(array);
    return 0;
}

你可能感兴趣的:(数组左上角到右下角最大值路径(动态规划))