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

网站建设及安全制度如何提高网站的用户粘度

网站建设及安全制度,如何提高网站的用户粘度,大国工匠网页制作素材,整站建设和网站优化最少硬币数问题 问题描述 给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。你可以认为每种硬…

最少硬币数问题

问题描述

给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。你可以认为每种硬币的数量是无限的。详见leetcode322

问题分析

设f(n)为amount=n时使用的最少金币数。遍历coins数组,选择f(n-coins[i])(i=0,1,coins.length-1)的最小值,即为需要的最少硬币数,递归继续寻找f(n-coins[i])的最小值,初始时f(0)=0,如果一些总金额无法凑成时,可以使用amount+1填充数组。

代码实现

public int coinChange(int[] coins, int amount) {int[] res = new int[amount+1];int max = amount+1;Arrays.fill(res,max);res[0] = 0;int[] temp = new int[coins.length];for(int i=1;i<amount+1;i++){for(int j=0;j<coins.length;j++){int leftAmount = i - coins[j];temp[j] = leftAmount>=0?res[leftAmount]+1:max;}int min = max;for(int j=0;j<coins.length;j++){min = Math.min(temp[j],min);}res[i]= min;}if(res[amount]==max){return -1;}return res[amount];
}

最长连续递增子序列

问题描述

给定一个未经排序的整数数组,找到最长且 连续递增的子序列,并返回该序列的长度。连续递增的子序列 可以由两个下标 l 和 r(l < r)确定,如果对于每个 l <= i < r,都有 nums[i] < nums[i + 1] ,那么子序列 [nums[l], nums[l + 1], …, nums[r - 1], nums[r]] 就是连续递增子序列。详见leetcode674

问题分析

这道题,我们之前使用滑动窗口的方式也可以解决,使用动态规划解题时,对于连续递增子序列的最后一个元素nums[k],存在两种情况,第一种是最长连续递增子序列长度为1,连续递增子序列只包含一个元素nums[k],第二种是存在k-1,使得nums[k-1]<num[k],设f[k]为到下标k处的连续递增子序列长度,则,如果nums[k-1]>=nums[k],f[k]=1,否则f[k]=f[k-1]+1,初始值f[0]=1,

代码实现

滑动窗口实现

public int findLengthOfLCIS(int[] nums) {     if(nums.length==0||nums.length==1){return nums.length;}int res = 1;int count =1;for(int i=1;i<nums.length;i++){if(nums[i-1]>=nums[i]){count =1;}else{count++;}if(count>res){res = count;}}return res;   
}

动态规划实现

public int findLengthOfLCIS(int[] nums) {int[] dp = new int[nums.length];Arrays.fill(dp,1);int max = 1;for(int i=1;i<nums.length;i++){if(nums[i]>nums[i-1]){dp[i] = dp[i-1]+1;max = Math.max(dp[i],max);}}return max;
}

最长递增子序列

问题描述

给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。详见leetcode300

问题分析

这道题与上一题相似,只是不需要连续递增。对于最长递增子序列的最后一个元素nums[k],存在两种情况,第一种是最长连续递增子序列长度为1,连续递增子序列只包含一个元素nums[k],第二种是存在i,使得i<k,nums[i]<num[k],设f[k]为到下标k处的连续递增子序列长度,则f[k] = max{f[i]+1}(i是所有nums[i]<nums[k]的集合)

代码实现

public int lengthOfLIS(int[] nums) {int[] dp = new int[nums.length];Arrays.fill(dp,1);for(int i=1;i<nums.length;i++){for(int j=i-1;j>=0;j--){if(nums[j]<nums[i]&&dp[j]+1>dp[i]){dp[i] = dp[j]+1;}}}int max = 1;for(int i=0;i<nums.length;i++){max = Math.max(max,dp[i]);}return max;
}

最少完全平方数

问题描述

给你一个整数 n ,返回 和为 n 的完全平方数的最少数量 。完全平方数 是一个整数,其值等于另一个整数的平方;换句话说,其值等于一个整数自乘的积。例如,1、4、9 和 16 都是完全平方数,而 3 和 11 不是。详见leetcode279

问题分析

设f(n)表示和为 n 的完全平方数的最少数量 。则f(n)=min{f(n-jj)+1}(j是满足所有jj<=n的j的集合).初始时f(0) = 0.

代码实现

public int numSquares(int n) {int[] f = new int[n+1];Arrays.fill(f,Integer.MAX_VALUE);f[0] = 0;for(int i=1;i<n+1;i++){for(int j=1;j*j<=i;j++){if(f[i-j*j]+1<f[i]){f[i] = f[i-j*j]+1;}}}return f[n];
}

跳跃游戏

问题描述

给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。详见leetcode55

问题分析

设f(n)是一个boolean数组,为true表示可以跳到数组下标n处,为false表示无法跳到数组下标n处。f(n)为true的条件是f(i)为true,n-1-i<nums[i],初始时f(0)=true

public boolean canJump(int[] nums) {boolean[] f = new boolean[nums.length];Arrays.fill(f,false);f[0] = true;for(int i=1;i<nums.length;i++){for(int j=0;j<i;j++){if(f[j]&&j+nums[j]>=i){f[i] = true;break;}}} return f[nums.length-1];
}

总结

这部分动态规划问题需要我们你想推导,即如何由我们想要结果的前一个状态得到我们想要的结果(往往是最值,所以涉及从前面多个状态到当前状态的选择)。逆向推导得到状态转移方程f,确定初始条件,一步步填充dp数组,最终得到我们想要的结果并返回。

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

相关文章:

  • 网站代理被抓校园网站开发设计报告
  • 网站设计师岗位职责wordpress4.9.2
  • 网站建立需要什么技术做网站前的准备工作
  • 东台建网站最能打动顾客的十句话
  • 自己做网站前期困难吗泰州网站建设服务公司
  • 校园二手交易网站要怎么做呀番茄todo社区看片在线观看
  • 网站模版配置数据库从0到建网站
  • 大丰哪家专业做网站wordpress微信扫码登录
  • 全域seo十堰优化排名技术厂家
  • 长春网站建设q.479185700惠我要自学网python
  • 网站建设包括哪些方面?网站制作网址
  • 个人网站的制作步骤建筑工程网络设计
  • 模板网站建设方案一个人做网站可以做什么
  • 台州英文网站建设做网站要准备哪些
  • 男女宾馆做爰视频网站中企做一个网站多少钱
  • 招远网站建设公司报价渝中网站建设
  • eclipse 做网站微信如何开小程序
  • 怎么创造一个网站扬州外贸网站seo
  • 做企业网站企业vi设计是什么意思啊
  • 企业应该如何进行网站推广长沙百度百科
  • 郑州平台网站建设网页 代码怎么做网站
  • 北京理工大学网站开发与应用网页界面设计流程
  • 企业网站里面的qq咨询怎么做久久建筑网20g三维图集下载
  • 重庆科技网站建设优化大师绿色版
  • 福州网站建设服务公司wordpress文章格式
  • 门户类型网站有哪些成都市医院网站建设
  • jquery网站源码世界做火的游戏视频网站
  • 企业手机网站建设特色网站架构价格
  • 图片演示dw做网站弹幕怎么做视频网站
  • 基于asp的网站开发定制网站设计方案