【算法题刷题笔记】华为OD机试 - 农场施肥

news2024/9/24 5:26:26
样例一:
5 7
5 7 9 15 10

>> 9

样例二:
3 1
2 3 4

>> -1

解题思路

题目大概意思: 给你N个数, 还有一个数M, 让你求K, 进行M次减K操作, 令这N个数都小于等于0。

思路: 利用二分来快速找到K [N, sum(N)], 找到后去验证。如果验证能行, 区间向左聚, 如果不能向右聚。

sum(N): N个数的和。

Python题解【二分查找】O(nlogn)

import math

class Solution:
    def check(self, target, nums, n):
        """
        验证是否可行
		"""
        count = 0
        for i in nums:
            if i <= target:
                count += 1
            else:
                count += math.ceil(i / target)
        return True if count <= n else False

    def run(self):
        m, n = map(int, input().split(" "))
        nums = list(map(int, input().split(" ")))
        l, r = 0, sum(nums)

        while l <= r:
            mid = (l + r) >> 1	# 除二
            if self.check(mid, nums, n):
                r = mid - 1	# 向左聚合
            else:
                l = mid + 1 # 向右聚合
        if l == -1 or l == sum(nums) + 1:
            print(-1)
            return
        print(l)


if __name__ == '__main__':
    Solution().run()

Java题解在这里插入图片描述

import java.util.*;

public class Solution {
    private boolean check(int target, int[] nums, int n) {
        int count = 0;
        for (int i : nums) {
            if (i <= target) {
                count += 1;
            } else {
                count += Math.ceil((double)i / target);
            }
        }
        return count <= n;
    }

    public void run() {
        Scanner scanner = new Scanner(System.in);
        int m = scanner.nextInt();
        int n = scanner.nextInt();
        int[] nums = new int[m];
        for (int i = 0; i < m; i++) {
            nums[i] = scanner.nextInt();
        }
        int l = 0, r = Arrays.stream(nums).sum();

        while (l <= r) {
            int mid = (l + r) >> 1;
            if (check(mid, nums, n)) {
                r = mid - 1;
            } else {
                l = mid + 1;
            }
        }
        if (l == -1 || l == Arrays.stream(nums).sum() + 1) {
            System.out.println(-1);
            return;
        }
        System.out.println(l);
    }

    public static void main(String[] args) {
        new Solution().run();
    }
}

Javascript题解在这里插入图片描述

function check(target, nums, n) {
    let count = 0;
    for (let i of nums) {
        if (i <= target) {
            count += 1;
        } else {
            count += Math.ceil(i / target);
        }
    }
    return count <= n;
}

function run() {
    const input = readline().split(' ').map(Number);
    const m = input[0];
    const n = input[1];
    const nums = readline().split(' ').map(Number);
    let l = 0, r = nums.reduce((a, b) => a + b);

    while (l <= r) {
        let mid = (l + r) >> 1;
        if (check(mid, nums, n)) {
            r = mid - 1;
        } else {
            l = mid + 1;
        }
    }
    if (l === -1 || l === nums.reduce((a, b) => a + b) + 1) {
        console.log(-1);
        return;
    }
    console.log(l);
}

run();

Go题解

在这里插入图片描述

package main

import (
	"fmt"
	"math"
)

func check(target int, nums []int, n int) bool {
	count := 0
	for _, i := range nums {
		if i <= target {
			count += 1
		} else {
			count += int(math.Ceil(float64(i) / float64(target)))
		}
	}
	return count <= n
}

func main() {
	var m, n int
	fmt.Scanf("%d %d", &m, &n)
	nums := make([]int, m)
	for i := 0; i < m; i++ {
		fmt.Scan(&nums[i])
	}
	l, r := 0, 0
	for _, v := range nums {
		r += v
	}

	for l <= r {
		mid := (l + r) >> 1
		if check(mid, nums, n) {
			r = mid - 1
		} else {
			l = mid + 1
		}
	}
	if l == -1 || l == r+1 {
		fmt.Println(-1)
		return
	}
	fmt.Println(l)
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/658456.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

frp配置多端口内网穿透?frp多端口怎么配置?

FRP内网穿透应用场景&#xff1a;本地Web服务外网访问、本地开发微信、本地联调支付宝\微信支付、TCP/UDP端口转发 在本机开发好的网站想让客户测试不在需要上传到服务器上面&#xff0c;使用FRP内外网穿透轻松解决&#xff1b;微信开发也不需要在上传到服务器&#xff0c;使用…

拒绝服务攻击

目录 一、初始DOS攻击与防御 1.1 DOS攻击概念 1.2 DOS攻击原因 1.2.1 内因 1.2.2 外因 1.3 DOS攻击原理 1.4 DOS攻击方法 二、DOS常见攻击技术 2.1 SYN Flood 2.1.1 基本思想 2.1.2 方法 2.1.3 防御措施 2.2 ICMP Flood 2.2.1 Smurf Flood 2.2.2 Ping of Death …

【微信小程序开发】第 10 课 - WXML 模版语法 - 数据绑定

欢迎来到博主 Apeiron 的博客&#xff0c;祝您旅程愉快 &#xff01; 时止则止&#xff0c;时行则行。动静不失其时&#xff0c;其道光明。 目录 1、缘起 2、数据绑定 2.1、绑定的基本规则 2.2、Mustache 语法的格式 2.2.1动态绑定内容 2.2.2动态绑定属性 2.2.3三元运…

Qqis中采用栅格工具生成XYZ瓦片(目录)简介

目录 前言 一、Qgis的相关功能 1、数据准备 2、将两个xyz图源添加到图层 二、Qgis栅格工具生成 1、生成xyz图块工具在哪里 2、生成xyz图块怎么用 3、下载结果 4、Leaflet加载离线瓦块 总结 前言 在上一篇博客中&#xff0c;介绍了一种在Qgis中基于QMetaTiles插件进行xyz瓦…

Linux---环境变量、$符号、自行设置环境变量

1. 环境变量 环境变量是操作系统&#xff08;Windows、Linux、Mac&#xff09;在运行的时候&#xff0c;记录的一些关键性信息&#xff0c;用以辅 助系统运行。 在Linux系统中执行&#xff1a;env命令即可查看当前系统中记录的环境变量 环境变量是一种Key-Value型结构&…

chatgpt赋能python:Python如何选取CSV某几列数据

Python如何选取CSV某几列数据 在数据处理过程中&#xff0c;CSV是一种非常常见的数据文件类型。CSV文件中的数据由逗号分隔的值&#xff08;Comma-Separated Values&#xff09;组成。处理CSV数据的任务之一是从CSV文件中选择特定的列数据&#xff0c;以进行数据分析或处理。在…

shell脚本基础

目录 一、概述 二、shell (一)shell命令解释环境 &#xff08;二&#xff09;类型 &#xff08;三&#xff09;查看系统中支持的shell&#xff1a;cat /etc/shells &#xff08;四&#xff09;查看系统默认shell&#xff1a; echo $SHELL 三、变量 &#xff08;一&…

HTMLCSS Day04 CSS盒模型

文章目录 1.盒子组成盒子属性&#xff08; Box properties&#xff09;marginborderpaddingwidth & height盒子一般指的是块元素&#xff0c;盒子是我们布局的重要机制。一个盒子应该由外边距、边框、内边距、内容组成。 - width & height- 边框属性1.什么是边框?2.边…

TiDB Contributor 资料汇总

作者&#xff1a; Billmay表妹 原文来源&#xff1a; https://tidb.net/blog/cf95cdb7 开源社区建设 TiDB 社区是由 TiDB 生态中的开发者、用户、合作伙伴一起建立的分享、学习平台。TiDB 线上社区汇聚了 29149 位 TiDB 资深用户&#xff08;注册用户数&#xff09;&#x…

将一个一维数组前段和后端的0元素去除的numpy.trim_zeros()方法

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 除去一维数组第一个非零元素之前的零 除去一维数组最后一个非零元素之后的零 numpy.trim_zeros() 选择题 关于以下代码说法错误的一项是? import numpy as np a np.array([0,0,1,0,2,0,0])…

前端Vue分享菜单按钮弹框、微博分享、QQ分享、微信好友、朋友圈

前端Vue分享菜单按钮弹框、微博分享、QQ分享、微信好友、朋友圈 &#xff0c; 下载完整代码请访问uni-app插件市场址:https://ext.dcloud.net.cn/plugin?id13085 效果图如下&#xff1a; #### 使用方法 使用方法 <!-- 分享 ref: 设置一个唯一ref contentHeight&#xff…

记一次fastjson事件应急响应

为方便您的阅读&#xff0c;可点击下方蓝色字体&#xff0c;进行跳转↓↓↓ 01 事件背景介绍02 事件分析过程03 事件分析结果04 安全加固建议 01 事件背景介绍 某内部应急演练中&#xff0c;安全部门收到通知&#xff0c;称公司内部资产被入侵&#xff0c;且可能已经开始内网横…

YOLO V2原理总结

yolo v2在yolo v1的基础上添加或更换了一些内容&#xff0c;一定程度上结局了yolo v1的一些问题。 ✨1 概括 做出的改变有8个&#xff1a; 添加Batch Normalization层高分辨率主干网络anchor box机制全卷积网络结构新的主干网络K-means聚类先验框使用更高分辨率特征多尺度训练…

(十)异步-委托异步调用(4)

一、委托异步执行 当委托对象被调用时&#xff0c;它调用其调用列表中包含的方法。这是同步完成的。 如果委托对象在调用列表中只有一个方法&#xff08;引用方法&#xff09;&#xff0c;它就可以异步执行这个方法。委托类有两个方法&#xff0c;叫作 BeginInvoke 和 EndInv…

【计算机网络】进程崩溃或网络中断后,TCP 连接还存在吗?

【计算机网络】进程崩溃或网络中断后&#xff0c;TCP 连接还存在吗&#xff1f; 参考资料&#xff1a; TCP 连接&#xff0c;一端断电和进程崩溃有什么区别&#xff1f; 拔掉网线后&#xff0c; 原本的 TCP 连接还存在吗&#xff1f; TCP/IP卷一:94—TCP保活机制 TCP Keepaliv…

记一次gitlab应急响应

为方便您的阅读&#xff0c;可点击下方蓝色字体&#xff0c;进行跳转↓↓↓ 01 事件背景介绍02 事件分析过程03 事件分析结果04 安全加固建议 01 事件背景介绍 某内部应急演练中&#xff0c;态势感知平台上出现gitlab RCE漏洞攻击成功告警&#xff0c;现需根据流量情况进行安全…

013、数据库管理之连接管理

连接管理 TiDB的连接特性连接TiDB 数据库开发接口支持 实验案例 TiDB的连接特性 无状态MySQL协议支持 100% 兼容MySQL 5.7协议支持MySQL 5.7常用功能与语法 MySQL 语法支持的限制&#xff08;不支持的功能特性&#xff09; 存储过程触发器外键函数其它 连接TiDB 数据库 使…

记一次shiro应急响应

为方便您的阅读&#xff0c;可点击下方蓝色字体&#xff0c;进行跳转↓↓↓ 01 事件背景介绍02 事件分析过程03 事件分析结果04 安全加固建议 01 事件背景介绍 某内部应急演练中&#xff0c;安全部门监测到WAF上存在shiro攻击成功告警信息&#xff0c;现需根据流量情况进行安全…

Vue中的表单上传与文件预览

Vue中的表单上传与文件预览 在Web应用程序中&#xff0c;文件上传和预览是非常常见的功能。在Vue中&#xff0c;我们可以使用axios和FormData来实现表单上传&#xff0c;使用FileReader来实现文件预览。在本文中&#xff0c;我们将介绍如何在Vue中实现表单上传和文件预览功能。…

[阿里云使用k8s技术部署微服务]

1.1 检查CPU/内存/网络设置 对虚拟机的要求(必须): CPU:最少2核 内存:master >4G&#xff0c;node >3G 网络:NAT模式 操作系统版本: Docker 要求 CentOS 系统的内核版本必须高于 3.10。 如果内核版本为3.10&#xff0c;则发行编号最好能升级到1127&#xff0c; 即:3.10.0…