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

晋中建设局查合同网站深圳外包网站

晋中建设局查合同网站,深圳外包网站,创意营销点子,桂林最新情况最新消息今天【LetMeFly】3201.找出有效子序列的最大长度 I:分类统计贪心(一次遍历) 力扣题目链接:https://leetcode.cn/problems/find-the-maximum-length-of-valid-subsequence-i/ 给你一个整数数组 nums。 nums 的子序列 sub 的长度为 x…

【LetMeFly】3201.找出有效子序列的最大长度 I:分类统计+贪心(一次遍历)

力扣题目链接:https://leetcode.cn/problems/find-the-maximum-length-of-valid-subsequence-i/

给你一个整数数组 nums

nums 的子序列 sub 的长度为 x ,如果其满足以下条件,则称其为 有效子序列

  • (sub[0] + sub[1]) % 2 == (sub[1] + sub[2]) % 2 == ... == (sub[x - 2] + sub[x - 1]) % 2

返回 nums最长的有效子序列 的长度。

一个 子序列 指的是从原数组中删除一些元素(也可以不删除任何元素),剩余元素保持原来顺序组成的新数组。

 

示例 1:

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

输出: 4

解释:

最长的有效子序列是 [1, 2, 3, 4]

示例 2:

输入: nums = [1,2,1,1,2,1,2]

输出: 6

解释:

最长的有效子序列是 [1, 2, 1, 2, 1, 2]

示例 3:

输入: nums = [1,3]

输出: 2

解释:

最长的有效子序列是 [1, 3]

 

提示:

  • 2 <= nums.length <= 2 * 105
  • 1 <= nums[i] <= 107

解题方法:分类统计

子序列如果是有效子序列(相邻两个元素之和 的奇偶性相同),只有以下三种可能:

  1. 全奇
  2. 全偶
  3. 一奇一偶交替排列

怎么一次遍历分别统计出这三种情况最长有效子序列呢?

  • 使用一个变量oddoddodd,统计数组钟奇数元素的个数(那么偶数元素的个数就是len(nums)−oddlen(nums) - oddlen(nums)odd);
  • 使用一个变量lastlastlast,代表上一个选中元素是奇是偶;并使用一个元素cntcntcnt统计选中了多少个奇偶交替排列的元素。

所谓贪心,体现在当方案为奇偶交替时,遇到和上一个元素奇偶不同的元素一定选(不选白不选),遍历结束则能得到奇偶交替方案的最长长度。

举个例子:2,0,3,5,42, 0, 3, 5, 42,0,3,5,4这个数组,遍历时遇到2,选还是不选?

选,不选干嘛以奇数开头吗?没必要,以奇数开头不就少选了个偶数吗。

而一次遍历过程中顺便统计下奇数个数就很简单了。

  • 时间复杂度O(x)O(x)O(x)
  • 空间复杂度O(1)O(1)O(1)

AC代码

C++
/** @Author: LetMeFly* @Date: 2025-07-16 13:16:29* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-07-16 13:19:44*/
#if defined(_WIN32) || defined(__APPLE__)
#include "_[1,2]toVector.h"
#endifclass Solution {
public:int maximumLength(vector<int>& nums) {int ans = 0;int odd = 0;bool last = nums[0] % 2 ? false : true;for (int t : nums) {if (t % 2) {odd++;if (!last) {last = true;ans++;}} else {if (last) {last = false;ans++;}}}return max(ans, max(odd, int(nums.size()) - odd));}
};
Python
'''
Author: LetMeFly
Date: 2025-07-16 13:16:29
LastEditors: LetMeFly.xyz
LastEditTime: 2025-07-16 13:36:53
'''
from typing import Listclass Solution:def maximumLength(self, nums: List[int]) -> int:ans = odd = 0last = False if nums[0] % 2 else Truefor t in nums:if t % 2:odd += 1if not last:last = Trueans += 1else:if last:last = Falseans += 1return max(ans, odd, len(nums) - odd)
Java
/** @Author: LetMeFly* @Date: 2025-07-16 13:16:29* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-07-16 13:41:23*/
class Solution {public int maximumLength(int[] nums) {int ans = 0;int odd = 0;boolean last = nums[0] % 2 == 0;for (int t : nums) {if (t % 2 == 0) {if (last) {last = false;ans++;}} else {odd++;if (!last) {last = true;ans++;}}}return Math.max(ans, Math.max(odd, nums.length - odd));}
}
Go
/** @Author: LetMeFly* @Date: 2025-07-16 13:16:29* @LastEditors: LetMeFly.xyz* @LastEditTime: 2025-07-16 13:40:18*/
package mainfunc maximumLength(nums []int) (ans int) {odd := 0last := nums[0] % 2 == 0for _, t := range nums {if t % 2 == 0 {if last {last = falseans++}} else {odd++if !last {last = trueans++}}}return max(ans, max(odd, len(nums) - odd))
}

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源


文章转载自:

http://8hlFwcr4.fmgwx.cn
http://F6hrcjB0.fmgwx.cn
http://WLG2nmHX.fmgwx.cn
http://DbLMalPY.fmgwx.cn
http://C4G62xpd.fmgwx.cn
http://b0RAKQdu.fmgwx.cn
http://CDmDpfxQ.fmgwx.cn
http://15cGFcSv.fmgwx.cn
http://sR59uzB5.fmgwx.cn
http://WMBFvUak.fmgwx.cn
http://PwhgWWYC.fmgwx.cn
http://YVwOuX0Y.fmgwx.cn
http://MNLGoaSA.fmgwx.cn
http://7Y5J0kP2.fmgwx.cn
http://Fo2Apwj7.fmgwx.cn
http://8T6ywRil.fmgwx.cn
http://I9JmdVPL.fmgwx.cn
http://BKDzhCZx.fmgwx.cn
http://4GnMcfBm.fmgwx.cn
http://nzekNCvG.fmgwx.cn
http://uVJCzd2f.fmgwx.cn
http://yirwjmh1.fmgwx.cn
http://MOFyUZoJ.fmgwx.cn
http://r5XuLwLH.fmgwx.cn
http://GkkzezRZ.fmgwx.cn
http://ekZCbj8Z.fmgwx.cn
http://aHpqYOg2.fmgwx.cn
http://sVyRVf1h.fmgwx.cn
http://RnKDF37P.fmgwx.cn
http://B8TWi915.fmgwx.cn
http://www.dtcms.com/wzjs/760020.html

相关文章:

  • 做幼儿网站的目标seo专业培训技术
  • 站长网网站模板中国工业品网
  • 做网站需要公司么网站外部推广
  • 网站建设为什么不清晰承德 网站建设 网络推广 网页设计
  • 宝山专业网站建设室内设计效果图一套方案
  • 郑州企业网站排名网站开发的几种语言
  • 网站关键词检测扬州建设集团招聘信息网站
  • 深圳网站搭建费用2015年做哪个网站能致富
  • 有哪些做特卖的网站有哪些谷歌推广一年多少钱
  • 官方网站建设必要性wordpress 外勤人员
  • 漳州网站开发点博大a优免费做简单网站
  • 构建一个网站的步骤宝安做棋牌网站建设
  • 天津网站建设icp备北京做网页公司
  • asp网站开发书籍东莞营销型网站建站
  • 高清品牌网站设计建设软文营销ppt
  • 诀窍的网站wordpress发表的文章在页面找不到
  • 个人网站 主机wordpress 虾米页面
  • 瀑布流网站源码网站可以做被告嘛
  • 为什么要做个人网站手机影视网站开发
  • 加强司法机关网站建设上海公共场所
  • 有没有便宜的网站建设seo编辑培训
  • 网站设置三方交易wordpress创建栏目
  • 我想投诉做软件的网站如何在网站上推广自己的链接
  • 织梦网站流动广告代码网站源码怎么绑定域名
  • 无锡网站制作方案网站建站目标
  • 兰州网站建设优化创意网红墙图片
  • 深圳公司免费网站建设怎么样网站后台登录界面代码
  • 一些做系统的网站石家庄seo
  • 网站的虚拟主机到期免费源码大全
  • 北京建设注册中心网站首页龙华高端网站设计