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

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

10个月前 (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;
    }
};




原创内容 转载请注明出处

分享给朋友:

相关文章

【深度优先搜索实战】力扣547题:省份数量问题的图论解法

【深度优先搜索实战】力扣547题:省份数量问题的图论解法

题目解读‌我们面对的是一个典型的图论问题:给定一个城市的连接矩阵,需要计算其中相互连通的城市群(省份)数量。这个问题可以抽象为无向图中的连通分量计算,每个城市代表图中的一个节点,城市之间的连接关系代表...

力扣第654题:最大二叉树解题教程 用数组构造最大二叉树

力扣第654题:最大二叉树解题教程 用数组构造最大二叉树

题目解读给定一个不含重复元素的整数数组,我们需要构建一棵最大二叉树。构建规则是:数组中的最大值作为根节点,其左侧子数组构建左子树,右侧子数组构建右子树,然后递归地应用这个规则。这种构建方式体现了分治思...

力扣540题:线性扫描法如何高效定位唯一数

力扣540题:线性扫描法如何高效定位唯一数

题目重解一个严格递增的有序数组中,除某个元素外,其余每个元素均出现两次。这个看似简单的条件背后隐藏着巧妙的规律——单一元素会打破数组的"成对对称性"。题目要求以O(log n)时间...

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

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

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

LeetCode 2778题解:平方和的高效计算与因数遍历优化(C++实现)

LeetCode 2778题解:平方和的高效计算与因数遍历优化(C++实现)

一、题目解读LeetCode 2778题要求计算数组中下标为n的因数的元素的平方和。例如,若n=6,其因数为1、2、3、6,则需计算nums[0]、nums[1]、nums[2]、nums[5]的平方...

洛谷2652题解析:同花顺排序问题的动态规划与滑动窗口优化

洛谷2652题解析:同花顺排序问题的动态规划与滑动窗口优化

一、题目解读洛谷2652题要求对一组扑克牌进行排序,目标是找到最少需要调整的次数,使得所有牌形成同花顺。题目中,扑克牌由花色和数字组成,需先按花色排序,再在同花色内按数字排序。核心难点在于如何处理花色...

发表评论

访客

看不清,换一张

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