leetcode 2856. 删除数对后的最小数组长度

news/2025/2/3 6:30:20 标签: leetcode, 算法, c++, 数据结构

题目如下
在这里插入图片描述
数据范围
在这里插入图片描述
示例
在这里插入图片描述

我们假设存在一个出现频率最高的数a那么我们可以把这个数组分成三部分那么第一部分和第三部分必然可以消去一部分 然后它们剩下的和a再消去
当a的数量是数组的一半那么显然剩下的就是0
当a的数量大于数组的一半那么显然存在无法消去的a 剩2 * count - n
当a的数量小于数组的一半1.当n为偶数(可以画图因为a不足一半就意味着当数组分成两组时a不会相互重叠例如  0 1 2 2 3 4 中2不重叠 或者可以用第一部分消去第三部分会刚好剩下a的数量个数然后再和a消)那么可以消去全部即剩0
										  2.当n为奇数 同上剩1
											即取决于n的奇偶性

通过代码

class Solution {
public:
    int minLengthAfterRemovals(vector<int>& nums) {
        int n = nums.size();
        int ans = n % 2;
        int count = ranges::upper_bound(nums,nums[n/2]) - ranges::lower_bound(nums,nums[n/2]);//a的数量大于一半时n/2的位置上必然是a
        return max(2 * count - n,ans);//如果a的数量小于一半那么第一个小于零 
    }
};

在这里插入图片描述


http://www.niftyadmin.cn/n/5840554.html

相关文章

Python之Excel操作 - 读取数据

我们将使用 openpyxl 库&#xff0c;它是一个功能强大且易于使用的库&#xff0c;专门用于处理 Excel 文件。 1. 安装 openpyxl 首先&#xff0c;你需要安装 openpyxl 库。你可以使用 pip 命令进行安装&#xff1a; pip install openpyxl2. 读取 Excel 文件 要读取 Excel 文…

每日一个小题

import pygame import random # 初始化 Pygame pygame.init() # 屏幕大小 screen_width 300 screen_height 600 block_size 30 # 颜色定义 colors [ (0, 0, 0), (255, 0, 0), (0, 150, 0), (0, 0, 255), (255, 120, 0), (255, 255, 0), (180, 0, 255), (0, 220, 220)…

用BGP的路由聚合功能聚合大陆路由,效果显著不?

正文共&#xff1a;666 字 11 图&#xff0c;预估阅读时间&#xff1a;1 分钟 之前我们统计过中国境内的IP地址和路由信息&#xff08;你知道中国大陆一共有多少IPv4地址吗&#xff1f;&#xff09;&#xff0c;不过数量比较多&#xff0c;有8000多条。截止到2021年底&#xff…

【算法】回溯算法专题② ——组合型回溯 + 剪枝 python

目录 前置知识进入正题小试牛刀实战演练总结 前置知识 【算法】回溯算法专题① ——子集型回溯 python 进入正题 组合https://leetcode.cn/problems/combinations/submissions/596357179/ 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以…

RocketMQ中的NameServer主要数据结构

1.前言 NameServer是RocketMQ中的一个比较重要的组件&#xff0c;我们这篇博客针对NameSever中包含的组件进行分析&#xff0c;分析一下NameServer中包含的组件以及组件的作用。以前我有一篇博客中rocketMq源码分析之搭建本地环境-CSDN博客&#xff0c;在这篇博客中就简单看了…

【C语言设计模式学习笔记1】面向接口编程/简单工厂模式/多态

面向接口编程可以提供更高级的抽象&#xff0c;实现的时候&#xff0c;外部不需要知道内部的具体实现&#xff0c;最简单的是使用简单工厂模式来进行实现&#xff0c;比如一个Sensor具有多种表示形式&#xff0c;这时候可以在给Sensor结构体添加一个enum类型的type&#xff0c;…

【go语言】grpc 快速入门

一、什么是 grpc 和 protobuf 1.1 grpc gRPC 是由 Google 开发的一个高效、开源的远程过程调用&#xff08;RPC&#xff09;框架&#xff0c;用于在分布式系统中进行通信。它是基于 HTTP/2 协议&#xff0c;支持多种语言&#xff0c;能够让不同的系统或应用程序&#xff08;即…

【大数据技术】案例01:词频统计样例(hadoop+mapreduce+yarn)

词频统计(hadoop+mapreduce+yarn) 搭建完全分布式高可用大数据集群(VMware+CentOS+FinalShell) 搭建完全分布式高可用大数据集群(Hadoop+MapReduce+Yarn) 在阅读本文前,请确保已经阅读过以上两篇文章,成功搭建了Hadoop+MapReduce+Yarn的大数据集群环境。 写在前面 Wo…