2023-07-15:给你一个 非递减 的正整数数组 nums 和整数 K,

判断该数组是否可以被分成一个或几个 长度至少 为 K 的 不相交的递增子序列。

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

输出:true。

答案2023-07-15:

大体步骤如下:

1.初始化计数变量 cnt 和最大计数变量 maxCnt,初始值都为 1。

2.从索引 1 开始遍历数组 nums

  • 如果 nums[i-1] 不等于 nums[i],说明遇到了一个新的递增序列,更新 maxCnt 为之前的计数 cntmaxCnt 中的较大值,并将 cnt 重置为 1。

  • 否则,递增序列继续,将 cnt 自增 1。

3.遍历结束后,再次更新 maxCnt 为最后一个递增序列的计数 cntmaxCnt 中的较大值。

4.判断长度为 len(nums) 除以 maxCnt 后是否大于等于 k,如果是,返回 true;否则,返回 false

5.在 main 函数中,定义数组 nums 和整数 k

6.调用函数 canDivideIntoSubsequences(nums, k) 并将结果赋给变量 result

7.输出结果 Result: true

时间复杂度:

遍历数组 nums 的时间复杂度为 O(n),其中 n 是数组 nums 的长度。

因此,整个算法的时间复杂度为 O(n)。

空间复杂度:

算法使用了常数级别的额外空间,不随输入规模变化,所以空间复杂度为 O(1)。

go完整代码如下:

package main

import (
"fmt"
) func canDivideIntoSubsequences(nums []int, k int) bool {
cnt := 1
maxCnt := 1 for i := 1; i < len(nums); i++ {
if nums[i-1] != nums[i] {
maxCnt = max(maxCnt, cnt)
cnt = 1
} else {
cnt++
}
} maxCnt = max(maxCnt, cnt)
return len(nums)/maxCnt >= k
} func max(a, b int) int {
if a > b {
return a
}
return b
} func main() {
nums := []int{1, 2, 2, 3, 3, 4, 4}
k := 3 result := canDivideIntoSubsequences(nums, k)
fmt.Println("Result:", result)
}

rust完整代码如下:

fn can_divide_into_subsequences(nums: &[i32], k: i32) -> bool {
let mut cnt = 1;
let mut max_cnt = 1; for i in 1..nums.len() {
if nums[i - 1] != nums[i] {
max_cnt = max_cnt.max(cnt);
cnt = 1;
} else {
cnt += 1;
}
} max_cnt = max_cnt.max(cnt);
nums.len() as i32 / max_cnt >= k
} fn main() {
let nums = vec![1, 2, 2, 3, 3, 4, 4];
let k = 3; let result = can_divide_into_subsequences(&nums, k);
println!("Result: {}", result);
}

c++完整代码如下:

#include <iostream>
#include <vector>
#include <algorithm> using namespace std; bool canDivideIntoSubsequences(vector<int>& nums, int k) {
int cnt = 1;
int maxCnt = 1; for (int i = 1; i < nums.size(); i++) {
if (nums[i - 1] != nums[i]) {
maxCnt = max(maxCnt, cnt);
cnt = 1;
}
else {
cnt++;
}
} maxCnt = max(maxCnt, cnt);
return nums.size() / maxCnt >= k;
} int main() {
vector<int> nums = { 1, 2, 2, 3, 3, 4, 4 };
int k = 3; bool result = canDivideIntoSubsequences(nums, k);
cout << "Result: " << boolalpha << result << endl; return 0;
}

c完整代码如下:

#include <stdio.h>

int canDivideIntoSubsequences(int nums[], int length, int k) {
int cnt = 1;
int maxCnt = 1; for (int i = 1; i < length; i++) {
if (nums[i - 1] != nums[i]) {
if (maxCnt < cnt) {
maxCnt = cnt;
}
cnt = 1;
}
else {
cnt++;
}
} if (maxCnt < cnt) {
maxCnt = cnt;
} return (length / maxCnt) >= k;
} int main() {
int nums[] = { 1, 2, 2, 3, 3, 4, 4 };
int length = sizeof(nums) / sizeof(nums[0]);
int k = 3; int result = canDivideIntoSubsequences(nums, length, k);
printf("Result: %s\n", result ? "true" : "false"); return 0;
}

2023-07-15:给你一个 非递减 的正整数数组 nums 和整数 K, 判断该数组是否可以被分成一个或几个 长度至少 为 K 的 不相交的递增子序列。 输入:nums = [1,2,2,3,3,的更多相关文章

  1. 一个数组求其最长递增子序列(LIS)

    一个数组求其最长递增子序列(LIS) 例如数组{3, 1, 4, 2, 3, 9, 4, 6}的LIS是{1, 2, 3, 4, 6},长度为5,假设数组长度为N,求数组的LIS的长度, 需要一个额外 ...

  2. 【LeetCode】665. 非递减数列 Non-decreasing Array(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 公众号:每日算法题 本文关键词:数组,array,非递减,遍历,python,C++ 目录 题目描述 题目大意 解题方法 一.错误代码 二.举例分析 ...

  3. [Swift]LeetCode665. 非递减数列 | Non-decreasing Array

    Given an array with n integers, your task is to check if it could become non-decreasing by modifying ...

  4. Leetcode 665.非递减数列

    非递减数列 给定一个长度为 n 的整数数组,你的任务是判断在最多改变 1 个元素的情况下,该数组能否变成一个非递减数列. 我们是这样定义一个非递减数列的: 对于数组中所有的 i (1 <= i ...

  5. LeetCode 665. 非递减数列(Non-decreasing Array)

    665. 非递减数列 665. Non-decreasing Array 题目描述 给定一个长度为 n 的整数数组,你的任务是判断在最多改变 1 个元素的情况下,该数组能否变成一个非递减数列. 我们是 ...

  6. Leetcode665.Non-decreasing Array非递减数组

    给定一个长度为 n 的整数数组,你的任务是判断在最多改变 1 个元素的情况下,该数组能否变成一个非递减数列. 我们是这样定义一个非递减数列的: 对于数组中所有的 i (1 <= i < n ...

  7. Java实现 LeetCode 665 非递减数列(暴力)

    665. 非递减数列 给你一个长度为 n 的整数数组,请你判断在 最多 改变 1 个元素的情况下,该数组能否变成一个非递减数列. 我们是这样定义一个非递减数列的: 对于数组中所有的 i (1 < ...

  8. [程序员代码面试指南]最长递增子序列(二分,DP)

    题目 例:arr=[2,1,5,3,6,4,8,9,7] ,最长递增子序列为1,3,4,8,9 题解 step1:找最长连续子序列长度 dp[]存以arr[i]结尾的情况下,arr[0..i]中的最长 ...

  9. 动态规划----最长递增子序列问题(LIS)

    题目: 输出最长递增子序列的长度,如输入 4 2 3 1 5 6,输出 4 (因为 2 3 5 6组成了最长递增子序列). 暴力破解法:这种方法很简单,两层for循环搞定,时间复杂度是O(N2). 动 ...

  10. 求解最长递增子序列(LIS) | 动态规划(DP)+ 二分法

    1.题目描述     给定数组arr,返回arr的最长递增子序列. 2.举例     arr={2,1,5,3,6,4,8,9,7},返回的最长递增子序列为{1,3,4,8,9}. 3.解答      ...

随机推荐

  1. MySQL(十二)索引使用的情况分析

    索引使用的情况分析 数据准备 创建表student_info.course CREATE TABLE `student_info` ( `id` int NOT NULL AUTO_INCREMENT ...

  2. 如何在现有项目中使用`Masa MiniApi`?

    首先我们现有创建一个空的WebApi的项目模板,这个项目模板和MasaFramework本身没有任何关联,我们本博客只是使用的MasaFramework的MiniApi的包 创建Asp.NET Cor ...

  3. Django 静态文件 request对象方法 pycharm和Django连接MySQL Django模型层初步了解 基本的ORM操作

    目录 静态文件 一.概念 静态文件:不经常变化的文件,主要针对html文件所使用到的各种资源. 例如:css文件.js文件.img文件.第三方框架文件 ps: Django针对静态文件资源需要单独在根 ...

  4. windows查看占用端口

    1. 查看占用 执行:netstat -ano 或者 netstat -aon|findstr 8080 2. 查看指定 PID 的进程 tasklist|findstr 3104 3. 结束进程 t ...

  5. 基于ChatGPT用AI实现自然对话

    1.概述 ChatGPT是当前自然语言处理领域的重要进展之一,通过预训练和微调的方式,ChatGPT可以生成高质量的文本,可应用于多种场景,如智能客服.聊天机器人.语音助手等.本文将详细介绍ChatG ...

  6. python使用docxtpl生成word模板

    python-docxtpl包简单使用和实战,Python处理word,docx文件. 最近需要处理一些爬虫得到的数据来进行一些自动化报告的操作,因为需要生成的是word的报告,所以估选用docxtp ...

  7. 2022-09-18:以下go语言代码输出什么?A:1;B:15;C:panic index out of range;D:doesn’t compile。 package main import

    2022-09-18:以下go语言代码输出什么?A:1:B:15:C:panic index out of range:D:doesn't compile. package main import ( ...

  8. 2021-05-12:给定一个数组arr,只能对arr中的一个子数组排序, 但是想让arr整体都有序。返回满足这一设定的子数组中,最短的是多长?

    2021-05-12:给定一个数组arr,只能对arr中的一个子数组排序, 但是想让arr整体都有序.返回满足这一设定的子数组中,最短的是多长? 福大大 答案2021-05-12: 从左往右遍历,缓存 ...

  9. 2021-10-22:颠倒二进制位。颠倒给定的 32 位无符号整数的二进制位。提示:请注意,在某些语言(如 Java)中,没有无符号整数类型。在这种情况下,输入和输出都将被指定为有符号整数类型,并且不

    2021-10-22:颠倒二进制位.颠倒给定的 32 位无符号整数的二进制位.提示:请注意,在某些语言(如 Java)中,没有无符号整数类型.在这种情况下,输入和输出都将被指定为有符号整数类型,并且不 ...

  10. 2021-09-29:不同路径。一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为

    2021-09-29:不同路径.一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 "Start" ).机器人每次只能向下或者向右移动一步.机器人试图达到网格的右 ...