leetcode:118. 杨辉三角

简介: 函数原型:int** generate(int numRows, int* returnSize, int** returnColumnSizes)参数解析:numRows是指明要求前几行杨辉三角 returnSize是返回指针数组的元素个数 returnColumnSizes是指明杨辉三角每一行有几个元素

一、题目

eb3dfae1cbcd96d1087387139d760a54_4cd2f05a67884485b76cdc8cd2549f7a.png

函数原型:int** generate(int numRows, int* returnSize, int** returnColumnSizes)


参数解析:numRows是指明要求前几行杨辉三角


                 returnSize是返回指针数组的元素个数


                 returnColumnSizes是指明杨辉三角每一行有几个元素


二、思路


       既然需要函数返回值类型是int**,那么需要返回一个指针数组。先创建一个指针数组ret,并为其申请空间。returnSize是指针数组元素个数,那么也就等于numRows。每一个指针数组中的一个元素又是一个数组,returnColumnSizes就表示该数组的大小。


       经过观察杨辉三角,发现每一行除去第一个和最后一个元素,其余元素值都等于上一行邻近的两个数之和。因此设置头指针与尾指针,头指针初始指向每一行第二个元素,尾指针初始指向每一行倒数第二个元素。设置循环,新的一行值用上一行的相邻两个元素相加得到,每一行首尾元素值为1,无需计算。


       当杨辉三角行数小于等于3时,每一行的值都可以直接赋值,无需计算。当行数大于等于4时,需要利用循环和首位指针得到每一行的元素值。最后返回指针数组ret。

int** generate(int numRows, int* returnSize, int** returnColumnSizes) 
{
  *returnSize = numRows;//返回数组个数等于numRows
  int** ret = (int**)malloc(sizeof(int*) * numRows);//返回的数组指针
  *returnColumnSizes = malloc(sizeof(int)* numRows);
  int left = 0;//头指针
  int right = 0;//尾指针
  int i = 0;
  //int j = 0;
  for (i = 0; i < numRows; i++)
  {
  (*returnColumnSizes)[i] = i + 1;
  ret[i] = (int*)malloc(sizeof(int) * (i + 1));
  if (i == 0 )
  {
    ret[i][0] = 1;
  }
  if (i == 1)
  {
    ret[i][0] = 1;
    ret[i][1] = 1;
  }
  if (i == 2)
  {
    ret[i][0] = 1;
    ret[i][1] = 2;
    ret[i][2] = 1;
    left = 1;
    right = i - 1;
  }
  if (i >= 3)
  {
    ret[i][0] = 1;
    ret[i][i] = 1;
    left = 1;
    right = i - 1;
    while (left <= right)
    {
    ret[i][left] = ret[i - 1][left] + ret[i - 1][left - 1];
    ret[i][right] = ret[i - 1][right] + ret[i - 1][right - 1];
    left++;
    right--;
    }
    left = 1;
    right = i - 1;
  }
  }
  return ret;
}


目录
相关文章
|
6月前
|
索引
leetcode-119:杨辉三角 II
leetcode-119:杨辉三角 II
59 0
|
5月前
|
缓存 算法 数据可视化
LeetCode 题目 119:杨辉三角 II
LeetCode 题目 119:杨辉三角 II
|
5月前
|
存储 SQL 算法
LeetCode 题目 118:杨辉三角
LeetCode 题目 118:杨辉三角
|
6月前
leetcode代码记录(杨辉三角
leetcode代码记录(杨辉三角
39 1
【每日一题】4.LeetCode——杨辉三角
【每日一题】4.LeetCode——杨辉三角
|
6月前
leetcode-118:杨辉三角
leetcode-118:杨辉三角
56 0
|
算法
【LeetCode】136. 只出现一次的数字、118. 杨辉三角
目录 136. 只出现一次的数字 118. 杨辉三角
49 0
力扣118.杨辉三角
给定一个非负整数 numRows生成「杨辉三角」的前 numRows行。在「杨辉三角」中,每个数是它左上方和右上方的数的和。链接位置:力扣。
45 0
|
2月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
3月前
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
110 2