2022-04-13:给你一个下标从 0 开始包含 n 个正整数的数组 arr ,和一个正整数 k 。 如果对于每个满足 k <= i <= n-1 的下标 i ,都有 arr[i-k] <= arr

Posted 福大大架构师每日一题

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2022-04-13:给你一个下标从 0 开始包含 n 个正整数的数组 arr ,和一个正整数 k 。 如果对于每个满足 k <= i <= n-1 的下标 i ,都有 arr[i-k] <= arr相关的知识,希望对你有一定的参考价值。

2022-04-13:给你一个下标从 0 开始包含 n 个正整数的数组 arr ,和一个正整数 k 。
如果对于每个满足 k <= i <= n-1 的下标 i ,都有 arr[i-k] <= arr[i] ,那么我们称 arr 是 K 递增 的。
比方说,arr = [4, 1, 5, 2, 6, 2] 对于 k = 2 是 K 递增的,因为:
arr[0] <= arr[2] (4 <= 5)
arr[1] <= arr[3] (1 <= 2)
arr[2] <= arr[4] (5 <= 6)
arr[3] <= arr[5] (2 <= 2)
但是,相同的数组 arr 对于 k = 1 不是 K 递增的(因为 arr[0] > arr[1]),
对于 k = 3 也不是 K 递增的(因为 arr[0] > arr[3] )。
每一次 操作 中,你可以选择一个下标 i 并将 arr[i] 改成任意 正整数。
请你返回对于给定的 k ,使数组变成 K 递增的 最少操作次数 。
力扣2111。

答案2022-04-13:

拆分成k个数组,分别求最长递增子序列,然后做差,最后求和。

代码用golang编写。代码如下:

package main

import "fmt"

func main() 
	arr := []int5, 4, 3, 2, 1
	k := 2
	ret := kIncreasing(arr, k)
	fmt.Println(ret)


func kIncreasing(arr []int, k int) int 
	n := len(arr)
	// a / b = 向下取整
	// a / b 向上取整 -> (a + b - 1) / b
	help := make([]int, (n+k-1)/k)
	ans := 0
	for i := 0; i < k; i++ 
		ans += need(arr, help, n, i, k)
	
	return ans


// arr[start , start + k, start + 2k, start + 3k,....]
// 辅助数组help,为了求最长递增子序列,需要开辟的空间,具体看体系学习班
// 上面的序列,要改几个数,能都有序!
func need(arr, help []int, n, start, k int) int 
	j := 0
	size := 0
	for ; start < n; start, j = start+k, j+1 
		size = insert(help, size, arr[start])
	
	return j - size


func insert(help []int, size, num int) int 
	l := 0
	r := size - 1
	m := 0
	ans := size
	for l <= r 
		m = (l + r) / 2
		if help[m] > num 
			ans = m
			r = m - 1
		 else 
			l = m + 1
		
	
	help[ans] = num
	if ans == size 
		return size + 1
	 else 
		return size
	


执行结果如下:


左神java代码

以上是关于2022-04-13:给你一个下标从 0 开始包含 n 个正整数的数组 arr ,和一个正整数 k 。 如果对于每个满足 k <= i <= n-1 的下标 i ,都有 arr[i-k] <= arr的主要内容,如果未能解决你的问题,请参考以下文章

2022-03-16:给你一个整数 n ,表示有 n 个专家从 0 到 n - 1 编号。 另外给一个下标从 0 开始的二维整数数组 meetings , 其中 meetings[i] = [xi,

2022-07-13:给你一个整数数组 arr ,你一开始在数组的第一个元素处(下标为 0)。 每一步,你可以从下标 i 跳到下标 i + 1 i - 1 或者 j : i + 1 需满足:i +

力扣 2155. 分组得分最高的所有下标

2022-11-07:给你一个 n 个节点的 有向图 ,节点编号为 0 到 n - 1 ,其中每个节点 至多 有一条出边。 图用一个大小为 n 下标从 0 开始的数组 edges 表示, 节点 i 到

2022-09-05:作为国王的统治者,你有一支巫师军队听你指挥。 :给你一个下标从 0 开始的整数数组 strength , 其中 strength[i] 表示第 i 位巫师的力量值。 对于连续的一

2022-04-09:给你两个长度分别 n 和 m 的整数数组 nums 和 multipliers ,其中 n >= m , 数组下标 从 1 开始 计数。 初始时,你的分数为 0 。 你需要执行恰