题目:给定一个非负整数 numRows,生成杨辉三角的前 numRows 行。 在杨辉三角中,每个数是它左上方和右上方的数的和。 示例: 输入: 5 输出: [ [1], [1,1], [1,2,1], [1,3,3,1], [1,4,6,4,1] ]
思路: 1.创建二维数组result保存结果,返回的数组个数为returnSize=numRows,returnColumnSizes[i]为 i +1 2.共计创建numRows行,每行第一个和最后一个置为1,从第二行开始有等式 result[i] [j] = result[i - 1] [j] + result[i-1] [j-1];
int** generate(int numRows, int* returnSize, int** returnColumnSizes){ int** result = (int**)malloc(sizeof(int*)*numRows); *returnSize = numRows;//返回的行数 *returnColumnSizes = (int *)malloc(sizeof(int)*numRows);//用来储存每一行的大小 for(int i = 0; i < numRows; i++) { (*returnColumnSizes)[i] = i+1; //注意此处一定要写成带括号的 result[i] = (int*)malloc(sizeof(int)*(i+1)); result[i][0] = 1; for(int j = i-1; j > 0; j--) { result[i][j] = result[i - 1][j] + result[i-1][j-1]; } result[i][i] = 1; } return result; }