leetcode 1675. Minimize Deviation in Array(最小化数组偏差)

news2024/10/3 8:28:44

在这里插入图片描述
数组里面有n个正整数,里面的数字可以无限次进行如下操作:
1.偶数可以除以2
2.奇数可以乘以2
数组中任意两元素差的最大值称为偏差。
把数组中的元素进行上面2种操作,使偏差最小。

思路:

数组中现有2种数字,一种是奇数,一种是偶数,
我们来分析下这2种数字能操作多少次

奇数可以 ✖2,✖2之后必然为偶数,然后就不能再乘了,
下一步只能➗2,但是➗2就会回到这个奇数本身。如果继续操作,就会无限循环。
所以奇数✖2后即可停止。

偶数可以➗2,➗2之后可能是奇数,也可能是偶数,
如果是偶数,可以继续➗2,
如果是奇数,只能✖2,那么就会回到这个偶数本身或者是中间过程的偶数。
所以在偶数➗2得到奇数时,就不应该再继续操作了,因为继续操作又会回到原点或中间点。

分析完之后,观察数组,直觉上应该如下解决此问题

数组排序,选最大的数,如果最大的是奇数,只能✖2,数字会继续变大,拉大偏差,因此没有操作性,
如果最大的数是偶数,可以➗2把它变小,缩小偏差,更新最小偏差,把➗2后的数字放回数组。

然后取最小的数,如果是奇数,把它✖2,缩小偏差,更新最小偏差,✖2后放回数组。

现在假设数字放回数组之后都会自动排序,

那么可以重复上面的步骤,直到最大的数字是奇数,最小的数字是偶数,这是终止条件。
(因为继续操作下去最大的会变大,最小的会变小,又拉大了偏差)

但是同时操作奇数和偶数会有如下麻烦
比如偶数➗2得到奇数,放回数组,那么下次想把最小的奇数✖2时,这个奇数是数组原有的奇数,还是偶数➗2后得到的奇数呢?
如果偶数➗2得到的奇数比原数组的奇数小,那么原数组的奇数可能就没有操作的机会。

所以要降低维度,只操作奇数或偶数
如果只操作奇数,那么偶数就没有操作的机会,
如果只操作偶数,只要奇数一开始的时候✖2变为偶数,那么它就可以变回原奇数。

所以在开始的时候,先把所有奇数✖2,整个数组都变为偶数,就可以达到只操作偶数的目的。
偶数➗2,一旦变为奇数,即停止。
每次➗2后要放回数组,同时数组要一直保持排序的状态,这样每次都能取出数组的最小值和最大值。
或者手动记录最小值,每次能取出最大值也可以(用优先队列)。

怎么能让数组一直保持排序的状态呢?用红黑树的数据结构,也就是TreeSet.

每操作一次,记录一次偏差的最小值,这个最小值可能是在中间过程中产生的。

    public int minimumDeviation(int[] nums) {
        int n = nums.length;
        TreeSet<Integer> ts = new TreeSet<>();
        

        for(int num : nums) {
            if(num % 2 != 0) num *= 2;
            ts.add(num);
        }
        
        int res = ts.last()-ts.first();

        while(ts.last() % 2 == 0) {
            ts.add(ts.pollLast() / 2);
            res = Math.min(res, ts.last()-ts.first());
        }

        return res;
    }

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

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

相关文章

新手如何入门黑客技术,黑客技术入门该学什么?

你是否曾经也对黑客技术感兴趣呢&#xff1f;感觉成为黑客是一件很酷的事&#xff0c;那么作为新手如何入门黑客技术&#xff0c;黑客技术入门该学什么呢&#xff1f; 其实不管你想在哪个新的领域里有所收获&#xff0c;你需要考虑以下几个问题。 首先你要想明白为什么学这个&…

程序员是世界上最理性、最睿智的群体,耶稣也反驳不了我,我说的!

有人说&#xff0c;程序员是吃青春饭的&#xff0c;35 岁就提前退休了。 猛一看&#xff0c;这句话是对的&#xff1b;仔细一看&#xff0c;这句话是不对的。 说它对&#xff0c;是因为现实中确实有很多程序员 35 岁就被毕业了&#xff1b;说它不对&#xff0c;是因为 35 岁以…

【数据库】redis集群环境详解

目录 集群环境 一&#xff0c;集群介绍 1、为什么需要redis集群 2、什么是redis集群 二&#xff0c;数据分片 三&#xff0c; 主从复制模型 四&#xff0c;一致性保证 五&#xff0c;集群搭建 1&#xff0c; 集群结构 2&#xff0c;创建配置文件 &#xff08;1&#…

播放器问答弹题功能(视频播放弹出问题)教程与实际演示案例

阿酷tony / 原创 / 2023-2-24 长沙问答弹题功能是指酷播云产品在视频播放的指定时间点弹出问答题目&#xff0c;适合在教学、培训类视频中使用。使用问答功能&#xff0c;既可以增加学生与内容的互动&#xff0c;有利于教学质量的提升&#xff0c;又可以评估学生的学习效果和课…

【 K8s 源码之调度学习】Pod 间亲和性和反亲和性的源码分析

查看案例 字段含义podAffinityPod 间的亲和性定义podAntiAffinityPod 间的反亲和性定义requiredDuringSchedulingIgnoredDuringExecution硬性要求&#xff0c;必须满足条件&#xff0c;保证分散部署的效果最好使用用此方式preferredDuringSchedulingIgnoredDuringExecution软性…

duilib.dll丢失怎么办?dll文件丢失修复方法分享

duilib.dll丢失怎么办&#xff1f;其实在使用 Windows 系统的过程中&#xff0c;有时会出现提示“duilib.dll丢失”的错误。这个错误可能会影响电脑的正常运行&#xff0c;但是不用担心&#xff0c;今天小编来给大家详细的讲解一下duilib.dll丢失都有哪些解决方法。 一.什么是…

SAFe(Scaled Agile Framework)学习笔记

1.SAFe 概述 SAFe&#xff08;Scaled Agile Framework&#xff09;是一种面向大型企业的敏捷开发框架&#xff0c;旨在协调多个团队和部门的协同工作&#xff0c;以实现高效的软件开发和交付。下面是SAFe框架的简单介绍总结&#xff1a; SAFe框架包括以下四个层次&#xff1a…

金测评 手感更细腻的游戏手柄,双模加持兼容更出色,雷柏V600S上手

很多朋友周末都喜欢玩玩游戏放松一下&#xff0c;在家玩游戏的时候&#xff0c;PC是大家常用的平台&#xff0c;当然了&#xff0c;玩游戏的时候用键鼠的话&#xff0c;手感难免差点意思&#xff0c;还是要手柄才能获得更好的体验。我现在用的是雷柏V600S&#xff0c;这是一款支…

飞鹅打印机怎么样?飞鹅打印机好用吗?飞鹅打印机怎么知道订单是否漏单?

外卖打印机怎么选?飞鹅打印机好用吗&#xff1f;飞鹅智能云打印机产品专注于云打印的解决方案和技术服务提供。2019 年飞鹅已经成为国内先进的云打印服务提供商&#xff0c;主要是服务美团、饿了么客户&#xff0c;产品主要优势&#xff1a;自动接单、自动打印&#xff0c;无需…

美好音乐不只在现场,索尼播放器NW-WM1ZM2和NW-WM1AM2满足聆听热爱

当两点一线的单调生活成了多数人的生活常态&#xff0c;那些有过程有讲究的仪式感开始变得弥足珍贵起来&#xff0c;爱乐者们不远千里奔赴音乐节、Livehouse的现场&#xff0c;除了追求当下高燃兴奋的感受&#xff0c;同样是为了获得一份全心投入的听音仪式感。而当不便出行的日…

.net core 本地环境切换网络遇到的问题 500.19 502.5 invalid_request

问题一 运行环境 IIS 部署.NET CORE 项目 出现 HTTP 错误 500.19 - Internal Server Error附上.NET CORE2.1版本的下载链接下载 .NET Core 2.1 (Linux、macOS 和 Windows) (microsoft.com)下载完成以后重启IIS&#xff0c;有的版本还需要在IIS设置.NET CLR版本为无托管代码二 H…

从0开始写Vue项目-Vue实现用户个人信息界面上传头像

从0开始写Vue项目-环境和项目搭建_慕言要努力的博客-CSDN博客从0开始写Vue项目-Vue2集成Element-ui和后台主体框架搭建_慕言要努力的博客-CSDN博客从0开始写Vue项目-Vue页面主体布局和登录、注册页面_慕言要努力的博客-CSDN博客从0开始写Vue项目-SpringBoot整合Mybatis-plus实现…

mybatis-plus深入学习篇(三)

mybatis-plus深入学习篇(三) 1 准备工作 1.1 建表sql语句(Emp表) SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS 0; -- ---------------------------- -- Table structure for emp -- ---------------------------- DROP TABLE IF EXISTS emp; CREATE TABLE emp (EMPNO int …

java原理4:java的io网络模型

文章目录1&#xff1a;基础概念1&#xff1a;同步和异步2&#xff1a;阻塞和非阻塞2.1&#xff1a;阻塞IO2.2&#xff1a;非阻塞io2.3&#xff1a;io复用3&#xff1a;同步/异步和阻塞/非阻塞3.1&#xff1a;同步非阻塞NIO4: redis为什么速度快Java 网络IO模型简介1&#xff1a…

VMware ESXi 8.0b - 领先的裸机 Hypervisor (Dell HPE Custom Image update)

本站发布 Dell 和 HPE 定制版 ESXi 8.0b 镜像 请访问原文链接&#xff1a;https://sysin.org/blog/vmware-esxi-8/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页&#xff1a;www.sysin.org 产品简介 VMware ESXi&#xff1a;专门构建的裸机 Hyper…

HTB-Photobomb

HTB-Photobomb信息收集开机提权对于问题的思考信息收集 端口扫描 目标首页 有一个http Authorization 目录扫描 在查看源码的时候发现了一个js文件。 并且发现了访问不存在的目录会出现错误提示。 通过搜索得知 Sinatra 是一个基于 Ruby 语言的 DSL&#xff08;领域…

2. Dart 开发工具环境配置

很多编辑器都可以用来开发dart&#xff0c;所以大家可以选择自己喜欢的编辑器去进行开发。我还是比较喜欢vs code如果你不用vs code来开发dart的话&#xff0c;这篇文章可以直接跳过。如果想要在vs code里有dart的语法提示&#xff0c;我们需要安装相关的插件如图点开插件输入d…

MySQL高可用 集群(MHA)

1. MHA集群概述 集群的定义&#xff1a;多台服务器一起提供相同的服务&#xff0c;如&#xff08;web集群&#xff09;等。常见集群的分类&#xff1a; LB&#xff08;负载均衡集群&#xff09;&#xff1a;服务器共同平均分摊处理客户端的多次连接请求。 HA&#xff08;高可用…

python库streamlit学习笔记

什么是streamlit&#xff1f; Streamlit是一个免费的开源框架&#xff0c;用于快速构建和共享漂亮的机器学习和数据科学Web应用程序。它是一个基于Python的库&#xff0c;专为机器学习工程师设计。数据科学家或机器学习工程师不是网络开发人员&#xff0c;他们对花几周时间学习…

Python近红外光谱分析与机器学习、深度学习方法融合实践技术

、 第一n入门基础【理论讲解与案 1、Python环境搭建&#xff08; 下载、安装与版本选择&#xff09;。 2、如何选择Python编辑器&#xff1f;&#xff08;IDLE、Notepad、PyCharm、Jupyter…&#xff09; 3、Python基础&#xff08;数据类型和变量、字符串和编码、list和tu…