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

农家乐网站开发项目背景情感营销

农家乐网站开发项目背景,情感营销,单位建设网站硬件,2013年建设工程发布网站题目 300. 最长递增子序列 中等 相关标签 数组 二分查找 动态规划 给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例…

题目

300. 最长递增子序列

中等

相关标签

数组   二分查找   动态规划

给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。

子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。

示例 1:

输入:nums = [10,9,2,5,3,7,101,18]
输出:4
解释:最长递增子序列是 [2,3,7,101],因此长度为 4 。

示例 2:

输入:nums = [0,1,0,3,2,3]
输出:4

示例 3:

输入:nums = [7,7,7,7,7,7,7]
输出:1

提示:

  • 1 <= nums.length <= 2500
  • -104 <= nums[i] <= 104

进阶:

  • 你能将算法的时间复杂度降低到 O(n log(n)) 吗?

思路和解题方法

  • if(nums.size()<=1) return nums.size();:特判,如果数组nums长度为0或1,直接返回其长度。
  • vector<int> dp(nums.size(), 1);:创建一个大小为nums长度的数组dp,用于存储以nums[i]结尾的最长上升子序列的长度。初始值全部赋为1,因为每个元素本身也可以构成一个长度为1的上升子序列。
  • int ans = 0;:初始化最长上升子序列的长度为0。
  • for(int i = 1; i < nums.size(); i++):从第二个元素开始遍历数组nums
  • for(int j = 0; j < i; j++):在i之前的元素中,找到比nums[i]小的元素。
  • if(nums[i] > nums[j]):如果nums[i]大于nums[j],则可以将nums[i]加入到以nums[j]结尾的最长上升子序列中。
  • dp[i] = max(dp[i], dp[j] + 1);:更新以nums[i]结尾的最长上升子序列的长度。当前位置的值为前面比它小的元素中以每个元素结尾的最长上升子序列长度的最大值+1。
  • if(ans < dp[i]) ans = dp[i];:更新最长上升子序列的长度。
  • return ans;:返回最长上升子序列的长度。

复杂度

        时间复杂度:

                O(n*n)

时间复杂度分析: 代码中使用了两重循环,时间复杂度为O(n^2)。

其中,内层循环每次迭代都会执行常数个操作(比较和更新dp数组),因此时间复杂度为O(1)。

外层循环的迭代次数为n-1,因此时间复杂度为O(n)。

因此,算法的总时间复杂度为O(n^2)。

        空间复杂度

                O(n)

空间复杂度分析: 代码中使用了一个长度为n的dp数组,因此空间复杂度为O(n)。

c++ 代码

class Solution {
public:int lengthOfLIS(vector<int>& nums) {if(nums.size()<=1) return nums.size();vector<int> dp(nums.size(), 1); // 创建一个dp数组,用于存储以nums[i]结尾的最长上升子序列的长度,默认初始为1int ans = 0; // 初始化最长上升子序列的长度为0for(int i = 1; i < nums.size(); i++) // 遍历数组nums{for(int j = 0; j < i; j++) // 在i之前的元素中,找到比nums[i]小的元素{if(nums[i] > nums[j]) // 如果nums[i]大于nums[j],则可以将nums[i]加入到以nums[j]结尾的最长上升子序列中dp[i] = max(dp[i], dp[j] + 1); // 更新以nums[i]结尾的最长上升子序列的长度}if(ans < dp[i]) // 更新最长上升子序列的长度ans = dp[i];}return ans; // 返回最长上升子序列的长度}
};

Java代码

class Solution {public int lengthOfLIS(int[] nums) {int[] dp = new int[nums.length]; // 创建一个大小为nums.length的数组dp,用于存储以nums[i]结尾的最长上升子序列的长度,默认初始为1int res = 0; // 初始化最长上升子序列的长度为0Arrays.fill(dp, 1); // 将dp数组中的元素全部赋值为1for (int i = 1; i < dp.length; i++) { // 遍历数组nums,从第二个元素开始for (int j = 0; j < i; j++) { // 在i之前的元素中,找到比nums[i]小的元素if (nums[i] > nums[j]) { // 如果nums[i]大于nums[j],则可以将nums[i]加入到以nums[j]结尾的最长上升子序列中dp[i] = Math.max(dp[i], dp[j] + 1); // 更新以nums[i]结尾的最长上升子序列的长度}res = Math.max(res, dp[i]); // 更新最长上升子序列的长度}}return res; // 返回最长上升子序列的长度}
}

觉得有用的话可以点点赞,支持一下。

如果愿意的话关注一下。会对你有更多的帮助。

每天都会不定时更新哦  >人<  。

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

相关文章:

  • 精仿腾讯3366小游戏门户网站源码织梦最新内核带全部数据!织梦教程网
  • 网站导航结构设计系统开发费用
  • 做视频播放网站 赚钱wordpress 图片分离
  • 做户型图的网站discuz网站开发
  • 一个网站如何做推广如何增加网站外链
  • 网站建设要多钱app跟网站的区别
  • 建站平台有哪些wordpress coming soon
  • 北京网站建设开发公司连锁会员管理系统
  • 叫人做网站要注意服装行业网站建设方案
  • 推荐优秀的企业网站设计网上ui设计培训
  • 网站推广网站制作网站建设公司徐州手机网站制作公司哪家好
  • 可视方便建站微网站哪个好怎么用网址导航源码
  • 扬中网站建设服务如何选择模板网站建设
  • Apple 手机网站制作宣传册设计与制作教程
  • 蒙阴网站建设个人网页背景图片大全
  • 如何用魔方网表做门户网站网站建站智能系统
  • 网站营销的定义西安网站到首页排名
  • 网站怎么做商桥网站备案找谁
  • 做720效果的还有哪个网站婚纱设计工作室
  • 那些网站分享pr做的视频wordpress模版建站
  • 个人怎么注册自己的网站苏州网站开发建设服务
  • 专业网站建设做网站需要学jsp
  • 找我家是做的视频网站好wordpress好还是dz
  • 深圳策划公司网站美食网页设计报告
  • 车陂手机网站建设电话大型网站的mssql数据库要付费吗
  • 如何进行网络推广和宣传郑州seo网站有优化
  • 福州市建设厅网站网站建设要托管服务器
  • 专业的培训网站建设网站建设公司销售技巧
  • 广东石油化工建设集团公司网站站长统计软件
  • 外贸常用社交网站有哪些wordpress提交页面反应迟钝