当前位置: 首页 > news >正文

Leetcode每日刷题之118.杨辉三角

1.题目解析

杨辉三角作为一个经典的数学模型,其基本原理相信大家已经耳熟能详,这里主要是在学习了vector之后,对于本题有了新的解法,更加简便。关于vector的基本使用详见 面向对象程序设计(C++)之 vector(初阶)

 

2.算法原理

杨辉三角主要的思想就是二维数组,并且要求是可变的,因为每一行的长度均有所差异,那么在C语言解法需要用到动态内存管理,并且需要使用两次,十分困难,这里使用STL中的vector会更加简便快速地解出本题

具体思路就是使用vector首先创建一个vector<vector<int>>二维数组,然后使用resize接口来创建每一行的列数,将其初始化为1,然后从第二行开始处理,最终实现杨辉三角

3.代码展示

class Solution {
public:vector<vector<int>> generate(int numRows) {vector<vector<int>> vv(numRows);for(size_t i = 0;i < numRows;i++){vv[i].resize(i+1,1);}for(size_t i = 2;i < vv.size();i++){for(size_t j = 1;j < vv[i].size() - 1;j++){vv[i][j] = vv[i-1][j] + vv[i-1][j-1];}}return vv;}
};

 

http://www.lryc.cn/news/426944.html

相关文章:

  • 【ARM 芯片 安全与攻击 5.2 -- 芯片中侧信道攻击与防御方法介绍】
  • XSS-games
  • 日撸Java三百行(day25:栈实现二叉树深度遍历之中序遍历)
  • 【vue讲解:ref属性、动态组件、插槽、vue-cli创建项目、vue项目目录介绍、vue项目开发规范、es6导入导出语法】
  • ubuntu:最新安装使用docker
  • Linux ssh 免密失效
  • k8s上部署ingress-controller
  • Android 13 about launcher3 (1)
  • 服务器数据恢复—raid5阵列热备盘未全部启用导致阵列崩溃的数据恢复案例
  • HTML—css
  • IO多路复用(Input/Output Multiplexing)
  • android与pc 用socket无线通信
  • 【流程引擎】springboot完美集成activiti工作流方案
  • 11、常见API
  • 渗透第三次作业
  • Python自动化:解锁高效工作与生产力的密钥
  • Sentinel1.8.1 控制台改造
  • 设计模式(2)行为型模式和七大原则
  • 学懂C++(三十一):高级教程——深入详解C++高级多线程编程技术之锁优化与替代
  • Linux - 基础工具使用
  • 理解线程id和简单封装原生线程库
  • Unified 阻抗控制 architecture、framework、approach
  • Java后端面试题(mq相关)(day9)
  • 算法-华为OD机试-识别有效的IP地址和掩码并进行分类统计
  • 钉钉开发网页应用JSAPI前端授权鉴权nodejs实现
  • uniapp 自定义全局弹窗
  • element+-ui图片无法使用--安装
  • Python编码系列—Python ORM(对象关系映射):高效数据库编程实践
  • 一次日志记录中使用fastjson涉及到ByteBuffer的教训
  • 掌握TCP连接管理与流量控制:从零开始