杨辉三角的队列实现-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; } }
这个时间复杂度跟其他差不多。但对杨辉三角和队列要有很好的理解。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通