• leetcode:118. 杨辉三角


    一、题目

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

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

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

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

    二、思路

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

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

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

    1. int** generate(int numRows, int* returnSize, int** returnColumnSizes)
    2. {
    3. *returnSize = numRows;//返回数组个数等于numRows
    4. int** ret = (int**)malloc(sizeof(int*) * numRows);//返回的数组指针
    5. *returnColumnSizes = malloc(sizeof(int)* numRows);
    6. int left = 0;//头指针
    7. int right = 0;//尾指针
    8. int i = 0;
    9. //int j = 0;
    10. for (i = 0; i < numRows; i++)
    11. {
    12. (*returnColumnSizes)[i] = i + 1;
    13. ret[i] = (int*)malloc(sizeof(int) * (i + 1));
    14. if (i == 0 )
    15. {
    16. ret[i][0] = 1;
    17. }
    18. if (i == 1)
    19. {
    20. ret[i][0] = 1;
    21. ret[i][1] = 1;
    22. }
    23. if (i == 2)
    24. {
    25. ret[i][0] = 1;
    26. ret[i][1] = 2;
    27. ret[i][2] = 1;
    28. left = 1;
    29. right = i - 1;
    30. }
    31. if (i >= 3)
    32. {
    33. ret[i][0] = 1;
    34. ret[i][i] = 1;
    35. left = 1;
    36. right = i - 1;
    37. while (left <= right)
    38. {
    39. ret[i][left] = ret[i - 1][left] + ret[i - 1][left - 1];
    40. ret[i][right] = ret[i - 1][right] + ret[i - 1][right - 1];
    41. left++;
    42. right--;
    43. }
    44. left = 1;
    45. right = i - 1;
    46. }
    47. }
    48. return ret;
    49. }

  • 相关阅读:
    react通过onChange传输select的value数据
    Rust开发——闭包使用示例
    IEEE期刊最新的影响因子
    云上未来,数智导航:阿里云研究院报告合集
    win10如何开启远程桌面连接
    苹果AirTag成为作案工具?偷车贼用其追踪高端汽车
    网络安全(黑客)小白学习笔记
    k8s、helm删除不掉资源问题处理
    【ArcGIS模型构建器】04:根据矢量范围批量裁剪影像栅格数据
    MCU简单的前后台软件架构
  • 原文地址:https://blog.csdn.net/2301_76197086/article/details/132989855