杨辉三角的队列实现-queue

复制代码
public class Solution {
    public IList<IList<int>> Generate(int numRows) {
        IList<IList<int>> rt = new List<IList<int>>(20);
        Queue queue = new Queue();
        int left =0,right=0;
        for(int i=0; i<numRows;i++) // 行数
        {
            var list = new List<int>(20);
            for(int k=0;k<=i;k++) // 有多少数据位
            {
                int num = 1;
                if(k != i) // k==i是右边界 1
                {
                    right = (int)queue.Dequeue(); // 出队元素先存入right中 这不是肯定1啊
                    if(k != 0) // k == 0是左边界 1
                    {
                        // 当前要打印的元素为上一行与之相邻的两元素之和
                        num = left + right;
                    }
                    left = right; // 右元素用过之后变为下一个打印元素的左元素
                }
                list.Add(num);
                queue.Enqueue(num);
            }
            rt.Add(list);
        }
        return rt;
    }
}
复制代码

这个时间复杂度跟其他差不多。但对杨辉三角和队列要有很好的理解。

posted @   vba是最好的语言  阅读(23)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示