2024-08-17:用go语言,给定一个从0开始的整数数组nums和一个整数k, 每次操作可以删除数组中的最小元素。 你的目标是通过这些操作,使得数组中的所有元素都大于或等于k。 请计算出实现这个目

2024-08-17:用go语言,给定一个从0开始的整数数组nums和一个整数k,

每次操作可以删除数组中的最小元素。

你的目标是通过这些操作,使得数组中的所有元素都大于或等于k。

请计算出实现这个目标所需的最少操作次数。

输入:nums = [2,11,10,1,3], k = 10。

输出:3。

解释:第一次操作后,nums 变为 [2, 11, 10, 3] 。

第二次操作后,nums 变为 [11, 10, 3] 。

第三次操作后,nums 变为 [11, 10] 。

此时,数组中的所有元素都大于等于 10 ,所以我们停止操作。

使数组中所有元素都大于等于 10 需要的最少操作次数为 3 。

答案2024-08-17:

chatgpt

题目来自leetcode3065。

大体步骤如下:

1.遍历数组nums,对于元素小于k的情况,将操作次数ans加1。

2.在给定例子中,初始时nums为[2, 11, 10, 1, 3],k为10。第一次操作后,删除最小元素1,得到[2, 11, 10, 3],操作次数为1。

3.第二次操作后,删除最小元素2,得到[11, 10, 3],操作次数为2。

4.第三次操作后,删除最小元素3,得到[11, 10],操作次数为3。

5.此时数组中的所有元素都大于或等于10,操作停止,使数组中所有元素大于等于10所需的最少操作次数为3。

总的时间复杂度为O(n),其中n为数组nums的长度,每个元素最多会被遍历一次。

总的额外空间复杂度为O(1),没有使用额外的数据结构来存储中间结果,只有常数级别的额外空间消耗。

Go完整代码如下:

package main

import (
	"fmt"
)

func minOperations(nums []int, k int) (ans int) {
	for _, x := range nums {
		if x < k {
			ans++
		}
	}
	return
}

func main() {
	nums := []int{2,11,10,1,3}
	k:=10
	fmt.Println(minOperations(nums, k))
}

在这里插入图片描述

Python完整代码如下:

# -*-coding:utf-8-*-

def min_operations(nums, k):
    ans = sum(1 for x in nums if x < k)
    return ans

nums = [2, 11, 10, 1, 3]
k = 10
print(min_operations(nums, k))

在这里插入图片描述

posted @   福大大架构师每日一题  阅读(22)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
历史上的今天:
2023-08-17 文心一言 VS 讯飞星火 VS chatgpt (77)-- 算法导论7.3 2题
2022-08-17 2022-08-17:以下go语言代码输出什么?A:运行时 panic;B:32;C:编译错误;D:0。 package main func main() { var x *struct {
2021-08-17 2021-08-17:谷歌面试题扩展版,面值为1~N的牌组成一组,每次你从组里等概率的抽出1~N中的一张,下次抽会换一个新的组,有无限组,当累加和<a时,你将一直抽牌,当累加和>=a且<b时,你将获胜
2020-08-17 2020-08-17:详细说下数据倾斜怎么解决?
点击右上角即可分享
微信分享提示