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

怀化租房网站网上找客户用什么软件

怀化租房网站,网上找客户用什么软件,中国经济网,网站建设内部风险分析70.爬楼梯 代码随想录原题,看这篇文章:C动态规划Part.1|动态规划理论基础、509.斐波那契数、70.爬楼梯、746.使用最小花费爬楼梯 118.杨辉三角 题目链接:118.杨辉三角 一刷代码 时间复杂度和空间复杂度都造到 O ( n u m R o w s 2 ) O(num…

70.爬楼梯

代码随想录原题,看这篇文章:C++动态规划Part.1|动态规划理论基础、509.斐波那契数、70.爬楼梯、746.使用最小花费爬楼梯

118.杨辉三角

题目链接:118.杨辉三角

一刷代码

时间复杂度和空间复杂度都造到 O ( n u m R o w s 2 ) O(numRows^2) O(numRows2)了。
基本思路就是先构造一个result存储最终的结果,然后定义一个dp数组来计算每一行的结果。

class Solution {
public:vector<vector<int>> generate(int numRows) {vector<vector<int>> result;for (int i = 0; i < numRows; i++) {vector<int> dp(i + 1, 1); // 行的大小应为i+1if (i >= 2) {  // 从第三行开始填充中间的数for (int j = 1; j < i; j++) {dp[j] = result[i - 1][j - 1] + result[i - 1][j]; // 正确使用result中的前一行}}result.push_back(dp);}return result;}
};

思路

很容易看到一个主要的性质:
杨辉三角中每个数字等于上一行的左右两个数字之和。

  • 确定dp数组下标和含义
    dp[i][j]等于第i行和第j列的值。

  • 确定递推公式
    递推公式很容易分析出来:
    dp[i][j] = dp[i - 1][j] + dp[i - 1][j - 1];
    也就是每个数字等于上一行左右两个数字之和,但是需要注意的是, 每一行的最左边和最右边的数字必须是1.

  • 初始化dp数组
    这里应该如何初始化呢?
    最直接的方式就是直接全部初始化成1,因为每一行除了第一个和最后一个元素,我们都能通过递推公式进行推导

  • 确定遍历顺序
    在leetcode的题目展示上面已经看的很清楚了,
    外循环从上往下遍历,内循环从左往右遍历。
    这里需要注意的是,由于每一行的元素个数都是变化的,所以关于行的初始化一定要在外循环中处理。代码如下:

for (int i = 0; i < numRows; ++i) {	//先遍历行dp[i].resize(i + 1); //将第i行的向量大小调整为i+1dp[i][0] = dp[i][i] = 1;for (int j = 1; j < i; +=j) {	//再遍历列dp[i][j] = dp[i - 1][j] + dp[i - 1][j - 1];}
}
  • 打印dp数组

还是比较简单的,这里就不写了。

CPP代码

其实思路还是很简单的,不过代码实现要一点小技巧,

  1. 在这里我们先创建一个大小为numRows的二维向量,其中每一行都是一个空的向量。在这种情况下,ret的初始状态是一个包含5行的二维向量,但每行都没有元素。
vector<vector<int>> dp(numRows);
  1. 然后我们在外循环中给每一行向量再调整大小,这样我们在原数组上做操作,空间复杂度一下就下来了。
for (int i = 0; i < numRows; ++i) {dp[i].resize(i + 1);...
}

总体代码如下

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

198.打家劫舍

代码随想录原题,看这篇文章:C++动态规划Part8|198.打家劫舍、213.打家劫舍II、198.打家劫舍III

http://www.yayakq.cn/news/15315/

相关文章:

  • wordpress不显示网站标题高端网站建设怎么做
  • 实验楼编程网站三网合一 营销型网站
  • 沧州市网站制作网站建设套餐怎么样
  • 高端集团网站建设公司自己制作一个网站需要多少钱
  • 微科技h5制作网站快速网站收录
  • 莱芜营销型网站制作深圳建设工程交易中心宝安中心
  • 网站不稳定html5新增标签
  • 城乡建设部统计信息网站培训心得体会怎么写
  • 网站关键词优化合同在线教育网站建设方案
  • 公司网站模板内容飞翔时代 网站建设
  • 网站建设ui苏宁易购官网商城
  • 深圳企业网站制作公司介绍江苏公司网站建设公司
  • 做网站购买服务器多少钱网站的点击率
  • 做的好的h游戏下载网站有哪些个人工作室如何做网站
  • 做招商类型的网站网站建设放在哪个费用
  • 滕州个人兼职做网站网站管理和维护怎么做
  • 网站必须要求备案吗免费网站建设特色
  • 交友深圳网站建设北京神州网站建设
  • 中车网站建设的优缺点网站代码输入完成之后要怎么做
  • 嘉兴南湖区优秀营销型网站建设飞机免费代理ip
  • 怎么自己做网站凑钱企业的做网站
  • 珠海网站设计培训学校泉州app制作
  • 怎样用电脑做网站企业网站中( )是第一位的。
  • 网站开发项目需要哪些人员策划师利尔化学股票
  • 保定附近的做网站价格个人网站的设计师
  • 一个销售网站的设计 应当是要如何建立一个网站共享
  • 万户网站制作一般通过486
  • 网站开发平台的含义大连网站制作仟亿科技
  • 手机版微网站dw如何发布网页
  • 如何利用网站来提升企业形象中国电子商务研究中心