当前位置:首页 > 力扣 > 力扣119题:从O(n²)到O(2n):杨辉三角高效空间优化

力扣119题:从O(n²)到O(2n):杨辉三角高效空间优化

2个月前 (05-18)

力扣119题:从O(n²)到O(2n):杨辉三角高效空间优化 杨辉三角形 C++ 算法 力扣 滚动数组 数组 第1张


题目重解:

给定一个非负索引 rowIndex,返回杨辉三角的第 rowIndex 行。不同于生成整个杨辉三角,这道题要求我们只返回特定行,且空间复杂度应尽可能优化。例如输入3,需要返回[1,3,3,1]。


解题思路:

1.使用两个一维数组交替存储当前行和上一行数据

2.通过now/pre指针异或运算实现数组切换

3.首尾元素固定为1,中间元素由上一行相邻元素相加得到

4.最终只需保留最后计算的行数据


代码详解:

class Solution {
public:
    vector<int> getRow(int rowIndex) {
       int a[2][34]; // 双数组存储空间
       int now=1;    // 当前写入数组索引
       int pre=0;    // 上一行数据数组索引
       a[pre][0]=1;  // 初始化第0行
       
       // 逐行计算
       for(int i=1;i<=rowIndex;i++) {
            for(int j=0;j<=i;j++) {
                if(j==i or j==0) {  // 首尾元素为1
                    a[now][j]=1;
                }
                else {  // 中间元素=上一行相邻元素之和
                    a[now][j]=a[pre][j]+a[pre][j-1];
                }
            }
            now^=1;  // 位运算切换数组
            pre^=1;  // 等价于now=(now+1)%2, pre=(pre+1)%2
       }
       
       // 组装结果
       vector<int> v;
       for(int i=0;i<=rowIndex;i++) {
            v.push_back(a[pre][i]); // 注意最后使用pre指针
       }
       return v;
    }
};




原创内容 转载请注明出处

分享给朋友:

相关文章

征服力扣704题:三步掌握经典二分查找算法

征服力扣704题:三步掌握经典二分查找算法

题目重解我们面对的是算法领域最经典的二分查找问题:在一个已排序的整数数组中,快速定位目标值的位置。就像在一本按字母顺序排列的字典中查找单词,我们不需要逐页翻阅,而是通过不断折半的方式快速缩小搜索范围,...

力扣144:递归之美 轻松掌握二叉树前序遍历

力扣144:递归之美 轻松掌握二叉树前序遍历

题目解读二叉树的前序遍历是一种基础但重要的树遍历方式,其遍历顺序为:先访问根节点,然后递归地前序遍历左子树,最后递归地前序遍历右子树。给定一个二叉树的根节点,我们需要按照这个顺序访问所有节点,并将它们...

标题:洛谷B3617题解析:八进制转十六进制算法实现与优化(附AC100代码)

标题:洛谷B3617题解析:八进制转十六进制算法实现与优化(附AC100代码)

一、题目解读洛谷B3617题要求将输入的八进制字符串转换为十六进制表示。题目需处理大数场景,且对输入合法性有明确限制(长度不超过1000,仅包含0-7字符)。由于八进制与十六进制无法直接转换,需借助十...

牛客14496题解:括号最大深度问题(栈思想与代码优化)

牛客14496题解:括号最大深度问题(栈思想与代码优化)

一、题目解读牛客14496题要求计算给定括号字符串中的最大深度。例如,对于字符串 "(()())",最大深度为2。题目考察对括号嵌套结构的理解,以及如何通过编程找到最深嵌套层次。二...

【洛谷1184题解析】用C++高效解决地点匹配问题(附代码与解题思路)

【洛谷1184题解析】用C++高效解决地点匹配问题(附代码与解题思路)

一、题目解读洛谷1184题要求处理一组地点列表与行程记录,统计其中匹配的天数。题目难点在于高效处理带有空格的字符串输入,以及快速判断每日行程是否在高手可去地点集合中。需要兼顾输入格式解析与算法效率。二...

牛客NC67题解:汉诺塔递归算法与解题步骤

牛客NC67题解:汉诺塔递归算法与解题步骤

一、题目解读牛客NC67题要求解决汉诺塔问题,这是一个经典的递归算法题目。题目给定整数n,代表汉诺塔中的盘子数量,需要输出将n个盘子从起始柱移动到目标柱的所有步骤。汉诺塔问题规则为:每次只能移动一个盘...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。