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

全国各大知名网站百度搜索引擎网站

全国各大知名网站,百度搜索引擎网站,网站建设经验介绍,北京疫情最新消息201970. 爬楼梯(进阶) 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? 示例 1: 输入:n 2 输出:2 解释:有两种方法可以爬到楼顶。 1. 1 阶 1 阶 2. 2…

70. 爬楼梯(进阶)

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。

每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

示例 1:

输入:n = 2

输出:2

解释:有两种方法可以爬到楼顶。 1. 1 阶 + 1 阶 2. 2 阶

示例 2:

输入:n = 3

输出:3

解释:有三种方法可以爬到楼顶。 1. 1 阶 + 1 阶 + 1 阶 2. 1 阶 + 2 阶 3. 2 阶 + 1 阶

问题分析:

1、确定dp数组以及下标的含义

dp[j]:爬到 j 阶有多少种方法

2、确定递推公式

完全背包,重复利用物品,且为排列数

楼顶为背包,每次爬的阶数为物品

所以递推公式为:

dp[j]=dp[j]+dp[j-i]

3、dp数组初始化

初始化dp[0]=1

4、确定遍历顺序

本题要求是排列数,{2,1}和{1,2}是两种方法,所以先遍历背包。列排序中,阶数1和阶数2都在同层出现,所以会出现{1,2}和{2,1},为排列数

5、打印dp数组

class Solution {public int climbStairs(int n) {int[] dp=new int[n+1];dp[0]=1;for (int j=0;j<=n;j++){for (int i=1;i<=2;i++){if (j>=i) {dp[j] = dp[j] + dp[j - i];}}}return dp[n];}
}

322. 零钱兑换

给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。

计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。

你可以认为每种硬币的数量是无限的。

示例 1:

输入:coins = [1, 2, 5], amount = 11
输出:3
解释:11 = 5 + 5 + 1

示例 2:

输入:coins = [2], amount = 3

输出:-1

示例 3:

输入:coins = [1], amount = 0

输出:0

问题分析:

 1、确定dp数组以及下标的含义

dp[j]:装满 j 的最少物品是dp[j]

2、确定递推公式

金额为背包,硬币为物品

选出最少的物品数,用min方法,比较上一个物品的dp[j]和需要凑齐本次的物品数+1

所以递推公式为:

dp[j]=Math.min(dp[j],dp[j-coins[i]]+1)

3、dp数组初始化

初始化dp[0]=0,非0初始化为Integer.MAX_VALUE,因为递推公式为选出最小值,防止被覆盖应该先初始化一个最大值。

4、确定遍历顺序

本题为组合数,先遍历物品,再遍历背包

5、打印dp数组

class Solution {public int coinChange(int[] coins, int amount) {int[] dp=new int[amount+1];for (int j=0;j<=amount;j++){dp[j]=Integer.MAX_VALUE;}dp[0]=0;for (int i=0;i<coins.length;i++){for (int j=coins[i];j<=amount;j++){if (dp[j-coins[i]]!=Integer.MAX_VALUE) {//避免出现面额凑不齐总金额的情况// 需要凑齐的前一步也无法凑齐//导致这一步也无法凑齐// 例如[2] 3dp[j] = Math.min(dp[j], dp[j - coins[i]] + 1);}}}/*  for (int i=0;i<coins.length;i++){for (int j=0;j<=amount;j++){System.out.print(dp[j]+" ");}System.out.println("\n");}*/if (dp[amount]==Integer.MAX_VALUE) return -1;return dp[amount];}
}

279.完全平方数

给你一个整数 n ,返回 和为 n 的完全平方数的最少数量 。

完全平方数 是一个整数,其值等于另一个整数的平方;换句话说,其值等于一个整数自乘的积。例如,149 和 16 都是完全平方数,而 3 和 11 不是。

示例 1:

输入:n = 12

输出:3

解释:12 = 4 + 4 + 4

示例 2:

输入:n = 13

输出:2

解释:13 = 4 + 9

问题分析:

 1、确定dp数组以及下标的含义

dp[j]:组成和为n的最少的平方和数有dp[j]个

2、确定递推公式

和为背包,数字为物品

每个物品都是平方和数,即为i*i

选出最少的物品数,用min方法,比较上一个物品的dp[j]和需要凑齐本次的物品数+1

所以递推公式为:

dp[j]=Math.min(dp[j],dp[j-i*i]+1)

3、dp数组初始化

初始化dp[0]=0,非0初始化为Integer.MAX_VALUE,因为递推公式为选出最小值,防止被覆盖应该先初始化一个最大值。

4、确定遍历顺序

本题为组合数,先遍历物品,再遍历背包

5、打印dp数组

class Solution {public int numSquares(int n) {int[] dp=new int[n+1];for (int j=0;j<=n;j++){dp[j]=Integer.MAX_VALUE;}dp[0]=0;for (int i=1;i*i<=n;i++){for (int j=i*i;j<=n;j++){dp[j]=Math.min(dp[j],dp[j-i*i]+1);}}/*for (int i=1;i*i<=n;i++){for (int j=1;j<=n;j++){System.out.print(dp[j]+" ");}System.out.println("\n");}*/return dp[n];}
}

 

http://www.hkea.cn/news/949015/

相关文章:

  • 怎么用文本做网站百度排行榜风云榜
  • 未来网站开发需求多搜索网站有哪几个
  • 网站建设 成都郑州高端网站制作
  • 快站怎么做淘客网站深圳关键词
  • 做网站时如何去掉网站横条小红书软文案例
  • 图虫南宁百度快速排名优化
  • 上城网站建设app推广文案
  • 网站建设特点宁波seo搜索引擎优化公司
  • 地产商网站建设网球新闻最新消息
  • 做爰全过程网站免费的视频谷歌seo搜索引擎
  • 怎么架设网站seo推广培训
  • 自己网站做问卷调查网页设计学生作业模板
  • 清远企业网站排名深圳网站建设系统
  • 互助平台网站建设费用卡点视频免费制作软件
  • 上海做b2b国际网站公司排名优化公司电话
  • 裙晖wordpress重庆seo整站优化
  • 乌克兰网站后缀谷歌浏览器下载电脑版
  • 建设部网站撤销注册资质的都是公职人员吗正规网络公司关键词排名优化
  • 杂志网站建设推广方案铜川网络推广
  • 网站建设后怎么搜索引擎优化解释
  • 网站建设维护 天博网络成都营销型网站制作
  • 秦皇岛北京网站建设百度广告投放电话
  • 团购做的比较好的网站营销推广ppt
  • 网站怎么做网站地图重庆网站制作公司哪家好
  • wordpress改地址后打不开seo品牌优化整站优化
  • 网页设计师证书含金量高吗百度网络优化
  • 咸阳网站开发长沙seo优化公司
  • 网站通cms国内十大搜索引擎排名
  • centos7安装 wordpress网站如何进行seo
  • 设计师灵感网站美国今天刚刚发生的新闻