Leetcode---376周赛---中位数贪心

题目列表

2965. 找出缺失和重复的数字

2966. 划分数组并满足最大差限制

2967. 使数组成为等数数组的最小代价

2968. 执行操作使频率分数最大

一、找到缺失和重复的数字

由于数据范围不是很大,可以直接暴力统计每个数字出现的次数,时间复杂度为O(n^2)

class Solution {
public:vector<int> findMissingAndRepeatedValues(vector<vector<int>>& grid) {vector<int>ans(2);int n=grid.size();vector<int>cnt(n*n+1);for(int i=0;i<n;i++){for(int j=0;j<n;j++){cnt[grid[i][j]]++;}}for(int i=1;i<=n*n;i++){if(cnt[i]==2){ans[0]=i;}else if(cnt[i]==0){ans[1]=i;}}return ans;}
};

二、划分数组并满足最大差限度

这题题目说的不是很清楚,这里的"子数组"不要求连续,即与数字的顺序无关(可以看示例),所以我们可以直接排序, 然后找元素的最大最小值,简单模拟一下

class Solution {
public:vector<vector<int>> divideArray(vector<int>& nums, int k) {vector<vector<int>>ans;int n=nums.size();sort(nums.begin(),nums.end());for(int i=0;i<n;i+=3){if(nums[i+2]-nums[i]<=k)ans.push_back({nums[i],nums[i+1],nums[i+2]});elsereturn {};}return ans;}
};

三、使数组成为等数数组的最小代价

这题的难点有两个:

1、回文数怎么处理?

2、抛开回文数,只看x,我们该如何选择x让它的代价尽可能的小?

问题1:回文数,要求左右数字对应相等,即我们只要枚举它的前半部分然后对称过去,就能得到一个回文数,我们这里选择先预处理得到数据范围内的所有回文串,具体看代码

问题2:如何选择x?这里是中位数贪心的思想,即x选择数组中的中位数最好。为什么?

结合上面两个问题的思路,我们来看看该如何写?首先我们有所有的回文数,然后我们通过中位数贪心知道,我们选择的回文数要尽可能的在中间位置,可以用二分找到附近的回文串,进行比较,找到最符合条件的

//预处理
vector<int>v;
int init=[](){for(int i=1;i<=10000;i*=10){//枚举回文串的前缀for(int j=i;j<i*10;j++){int x=j/10;int y=j;while(x){y=y*10+x%10;x/=10;}v.push_back(y);    }if(i<=1000){//i==10000会超范围,比如 12345 54321 数量级为1e9for(int j=i;j<i*10;j++){int x=j;int y=j;while(x){y=y*10+x%10;x/=10;}v.push_back(y);    }}}v.push_back(1000000001);//方便后面计算return 0;
}();class Solution {
public:long long minimumCost(vector<int>& nums) {sort(nums.begin(),nums.end());//中位数贪心一定要先排序int n=nums.size();auto cost=[&](int x)->long long{long long s=0;for(int i=0;i<n;i++)s+=abs(x-nums[i]);return s;};//找中位数附近的回文串,如果n为奇数,nums[(n-1)/2]为正中间那个数,如果n为偶数,nums[(n-1)/2]为中间两个数的左边那个int i=lower_bound(v.begin(),v.end(),nums[(n-1)/2])-v.begin();//如果n为奇数,不成立(因为(n-1)/2==n/2),得找前面的回文数和它比较//如果n为偶数,则nums[n/2]为中间两个数的右边那个,即v[i]在两个数之间,正好符合中位数贪心,直接放回if(nums[n/2]>=v[i])return cost(v[i]);//否则需要比较return min(cost(v[i]),cost(v[i-1]));}
};

四、执行操作使频率分数最大

这题其实也和中位数贪心有关。为了让一个数成为出现次数最大的众数,那么我们操作的这些数肯定是相邻的,因为它们本身就很接近,这样我们将单一数字变成我们希望的众数的操作次数才会尽可能的少,才能有更多的操作次数让其他的数更有可能变成我们想要的众数,增加众数的频率。

那么选择什么数作为众数比较好呢?

如果我们选择了一些连续的数字进行操作,那么根据中位数贪心的原理,我们选择的众数最好是这些数字的中位数,这样其它数字到它的距离之和才会是最小的,也就是操作次数最少。如果操作次数>k,就需要去掉一些数,如果操作次数<=k,就增加一些数,很明显的滑动窗口

代码如下

class Solution {typedef long long LL;
public:int maxFrequencyScore(vector<int>& nums, long long k) {sort(nums.begin(),nums.end());int ans=0;int n=nums.size();vector<LL>pre(n+1);for(int i=0;i<n;i++)pre[i+1]=pre[i]+nums[i];function<LL(LL,LL)>check=[&](LL l,LL r)->LL{LL mid=(l+r)/2;//这里的中位数下标要算对LL left=(mid-l)*nums[mid]-(pre[mid]-pre[l]);//中位数左边的数需要的操作数LL right=pre[r+1]-pre[mid+1]-(r-mid)*nums[mid];//中位数右边的数需要的操作数return left+right;};for(int l=0,r=0;r<n;r++){while(check(l,r)>k)l++;ans=max(ans,r-l+1);}return ans;}
};

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

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

相关文章

【Java中序列化的原理是什么(解析)】

&#x1f341;序列化的原理是什么&#xff1f; &#x1f341;典型-----解析&#x1f341;拓展知识仓&#x1f341;Serializable 和 Externalizable 接门有何不同? &#x1f341;如果序列化后的文件或者原始类被篡改&#xff0c;还能被反序列化吗?&#x1f341;serialVersionU…

一些简单OJ:进制转换,报数字,刷快手。

一、字符串转换成十进制整数 1、题目描述&#xff1a; 输入一个以#结束的字符串&#xff0c;本题要求滤去所有的非十六进制字符&#xff08;不分大小写&#xff09;&#xff0c;组成一个新的表示十六进制数字的字符串&#xff0c;然后将其转换为十进制数后输出。如果在第一个…

【SpringCloud笔记】(9)分布式配置中心之Config

Config 概述 分布式系统当前面临的配置问题 微服务意味着要将单体应用中的业务拆分成一个个子服务&#xff0c;每个服务的粒度相对较小&#xff0c;因此系统中会出现大量的服务。 比如&#xff1a;有n个微服务连接同一套数据库&#xff0c;当连接数据库需要发生变动时&…

RTSP交互过程

RTSP&#xff08;Real-Time Streaming Protocol&#xff09;是一种用于实时流媒体传输的应用层协议。在RTSP通信中&#xff0c;以下是参与的主要角色和组件&#xff1a; 客户端&#xff08;Client&#xff09;&#xff1a;发送请求并接收服务器的响应。客户端可以是一个播放器应…

Exploring the Limits of Masked Visual Representation Learning at Scale论文笔记

论文名称&#xff1a;EVA: Exploring the Limits of Masked Visual Representation Learning at Scale 发表时间&#xff1a;CVPR2023 作者及组织&#xff1a;北京人工智能研究院&#xff1b;华中科技大学&#xff1b;浙江大学&#xff1b;北京理工大学 GitHub&#xff1a;http…

ARM串口通信编程实验

完成&#xff1a;从终端输入选项&#xff0c;完成点灯关灯&#xff0c;打开风扇关闭风扇等操作 #include "gpio.h" int main() {char a;//char buf[128];uart4_config();gpio_config();while(1){//接收一个字符数据a getchar();//发送接收的字符putchar(a);switch(…

redis复习笔记01(小滴课堂)

高并发的必备两大“核技术”队列和缓存 介绍本地缓存和分布式缓存 Nosql介绍和Reidis介绍 Linux服务器源码安装Redis6和相关依赖 在路径下上传压缩包。 上传压缩包。 版本更新了&#xff0c;但这是临时的。 版本更新了。 解压压缩包&#xff1a; 重命名&#xff1a; 我们可以看…

c++中的引用()

引用 引用是c中的&#xff0c;在C语言中是无法使用的。 引用的作用&#xff1a; 引用可以理解为给变量起一个别名(这时候大家可能会想到typedef,但是它们不同(原因看后面))。起一个别名之后&#xff0c;我们使用变量别名其实就是使用变量自己,生活中,我们会有自己的小名,那…

C# WPF上位机开发(MySql访问)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 前面我们学习了数据库sqlite&#xff0c;不过这是一种小型的数据库&#xff0c;作为内部使用还可以。但是&#xff0c;如果要与外面的其他供应商进…

Android Intent 传递实体类到下一个 Activity

要在 Android 中通过 Intent 传递实体类对象&#xff0c;首先需要确保实体类对象实现了 Serializable 或 Parcelable 接口。 一、实现 Serializable 接口&#xff1a; public class MyObject implements Serializable {private String name;private int age;// 构造方法和其他…

蓝牙物联网在智慧医疗中的应用

物联网技术开启了万物互联的时代&#xff0c;并且随着智慧城市建设的加速推进及物联网技术对各行业的逐步渗透&#xff0c;“智慧”概念应运而生&#xff0c;诸如智慧能源、智慧交通、智慧医疗等“遍地开花”&#xff0c;可以说&#xff0c;物联网技术给各行业带来了产业模式上…

力扣labuladong一刷day46天并查集

力扣labuladong一刷day46天并查集 文章目录 力扣labuladong一刷day46天并查集一、323. 无向图中连通分量的数目二、130. 被围绕的区域三、990. 等式方程的可满足性 一、323. 无向图中连通分量的数目 题目链接&#xff1a;https://leetcode.cn/problems/number-of-connected-co…

转场动画路径动画

本篇文章我们介绍下转场动画及路径动画。 1、概述 转场动画有三种类型&#xff0c;页面间转场、组件内转场、共享元素转场。 2、页面间转场 页面间转场需要在全局pageTransition方法内配置页面入场和页面退场时的自定义转场动效。 2.1、函数说明 名称 参数 必填 参数描述…

Arduino/Android 蓝牙通信系统设计解决方案

随着当今安全管理的发展需求以及国家对安全监控行业的支持&#xff0c;这几年&#xff0c;安全监控行业发展迅猛&#xff0c;各类监控系统百花齐放。传统的温度监控系统通过有线或其他方式传送温度数据&#xff0c;而本文提出了利用蓝牙无线传输数据的设计方案&#xff0c;这种…

SLAM算法与工程实践——SLAM基本库的安装与使用(6):g2o优化库(3)构建g2o顶点

SLAM算法与工程实践系列文章 下面是SLAM算法与工程实践系列文章的总链接&#xff0c;本人发表这个系列的文章链接均收录于此 SLAM算法与工程实践系列文章链接 下面是专栏地址&#xff1a; SLAM算法与工程实践系列专栏 文章目录 SLAM算法与工程实践系列文章SLAM算法与工程实践…

FLStudio21中文版水果编曲软件好用吗?如何下载最新版本

FL Studio21版是一款在国内非常受欢迎的多功能音频处理软件&#xff0c;我们可以通过这款软件来对多种不同格式的音频文件来进行编辑处理。而且FL Studio 21版还为用户们准备了超多的音乐乐器伴奏&#xff0c;我们可以直接一键调取自己需要的音调。 FL Studio21版不仅拥有非常…

vue利用深拷贝解决修改不能取消的问题

vue利用深拷贝解决修改不能取消的问题 在对某数据进行修改时考虑还需要进行“确认”、“取消”操作&#xff0c;那么在取消时就需要返回保留的数据内容&#xff0c;那么如何将原有数据保留一份则是关键性问题。 显然修改值不能直接进行原值的赋值操作&#xff0c;因为这样无法取…

Hadoop——分布式计算

一、分布式计算概述 1. 什么是计算、分布式计算? 计算:对数据进行处理,使用统计分析等手段得到需要的结果分布式计算:多台服务器协同工作,共同完成一个计算任务2. 分布式计算常见的2种工作模式分散->汇总 (MapReduce就是这种模式)将数据分片,多台服务器各自负责一…

金和OA C6 gethomeinfo sql注入漏洞

产品介绍 金和网络是专业信息化服务商,为城市监管部门提供了互联网监管解决方案,为企事业单位提供组织协同OA系统开发平台,电子政务一体化平台,智慧电商平台等服务。 漏洞概述 金和 OA C6 gethomeinfo接口处存在SQL注入漏洞&#xff0c;攻击者除了可以利用 SQL 注入漏洞获取…

vue3+ts pinia存储及持久化

index.ts 需要安装pinia-plugin-persist npm i pinia-plugin-persist -Simport { createPinia} from "pinia" // 引入批量的pinia持久存储插件 import piniaPluginPersist from pinia-plugin-persist const storecreatePinia(); store.use(piniaPluginPers…