Leetcode---360周赛

news2024/12/23 17:10:56

题目列表

2833. 距离原点最远的点

2834. 找出美丽数组的最小和

2835. 使子序列的和等于目标的最少操作次数

2836. 在传球游戏中最大化函数值

一、距离原点最远的点

 这题主要是理解题意,遇到'L'往左走,遇到'R'往右走,遇到'_'左右都可以走,题目问移动完成后,距离原点的最长距离,这很显然,只有所有的‘_’都往一个方向走的时候,才是最大的

代码如下

class Solution {
public:
    int furthestDistanceFromOrigin(string moves) {
        int ret=0,l=0;
        for(int i=0;i<moves.size();i++){
            if(moves[i]=='L') l++;
            else if(moves[i]=='R') l--;
            else ret++;
        }
        ret+=abs(l);
        return ret;
    }
};

二、找出美丽数组的最小和

这题和359周赛的第二题一样,就不再写了,贴个代码

class Solution {
public:
    long long minimumPossibleSum(int n, int target) {
        long long m=min(target/2,n);
        return m*(m+1)/2+(target+target+(n-m-1))*(n-m)/2;
    }
};

三、使子序列的和等于目标的最小操作次数

这题思路在于,题目给的数组存放的是2的幂,我们要想到数的二进制表示,从而想到用nums中的数据来凑出target的每一个二进制位上的1。

而target的每一个二进制上的1,有三个来源:

1.数组本身就有

2.用<2^i的数凑出一个2^i

3.将大于2^i的数拆分成我们需要的2^i

而题目要求我们返回最少的操作次数,那么我们肯定优先前两个方案,尽量避免拆分,所以我们将nums数组排序,并且从低位开始枚举target的二进制位上的1

方案一和方案二可以合并成:用<=2^i的数字凑出2^i

首先我们明确<=2^i的各个数字之和一定>=2^i才有可能凑出2^i,接下来,我们用数学归纳法进行证明用<=2^i的数子之和>=2^i的这些数一定能凑出2^i,s代表<=2^i的数字之和

当i=1,s>=2时,用<=2的数凑出2

1)如果存在2,很显然直接得到2

2)如果不存在2,那么<2^1的数字只能是1,而1相加很显然能得到2^1

所以,<=2^1的数字之和>=2^1的这些数一定能凑出2^1

当i=2,s>=4时,用<=4的数凑出4

1)如果存在4,显然能得到4

2)如果不存在4,<4的数字只能是1/2,即<=2^1,且s>=4>=2,所以根据上面的结论,得到一个2,剩下s-2>=2,同理,还能得到一个2,两个2相加得到4

所以,<=2^2的数字之和>=2^2的这些数一定能凑出2^2

当i=3,s>=8时,用<=8的数凑出8

1)如果存在8,显然能得到8

2)如果不存在8,<8的数字只能是1/2/4,即<=2^2,且s>=8>=4,所以根据上面的结论,得到一个4,剩下s-4>=4,同理,还能得到一个4,两个4相加得到8

所以,<=2^3的数字之和>=2^3的这些数一定能凑出2^3

综上所诉,一直这样推到下去就会得到:用<=2^i的数子之和>=2^i的这些数一定能凑出2^i

方案三:根据题目要求,我们选择数组中离2^i最近的2^j (j>i) 进行拆分,这样操作次数最少,而我们很容易知道,一旦差分了2^j,那么2^(i+1),2^(i+2),...,2^(j-1)就都不用考虑了,因为在拆分2^j时,已经得到了这些数,拆分的次数为 j-i (可以找个例子看看)

那么这题什么时候返回-1,我们知道任何一个2的幂都能被拆成1,所以只有数组之和小于target时,才会返回-1

技巧:当我们在凑出2^i之后,原本的算法应该是需要减去2^i,再去看剩下的数能不能凑出下一个2^i,但是我们也可以只加不减,只要我们在比较时,连同target的二进制i位之前的位数一起比较

代码如下

class Solution {
public:
    int minOperations(vector<int>& nums, int target) {
        //返回-1的情况
        if(accumulate(nums.begin(),nums.end(),0LL)<target)
            return -1;
        //记录每一位二级制1的个数
        long long cnt[32]={0};
        for(auto&x:nums)
            cnt[__builtin_ctz(x)]++;//__builtin_ctz得到最右边二进制位1的位数
        int i=0,ret=0;
        long long sum=0;
        while(target>=(1u<<i)){
            sum+=cnt[i]<<i;
            int mask=(1u<<(i+1))-1;//小技巧
            if(sum>=(mask&target)){//能凑出来
                i++;
                continue;
            }
            //需要拆分
            i++,ret++;
            while(cnt[i]==0)
                i++,ret++;
        }
        return ret;
    }
};

四、在传球游戏中最大化函数值

 这题题目看起来很复杂,但是其实就是让你求传k次球之后得到的最大下标和,如果直接暴力,这题的数据范围肯定会超时,所以这题就是让我们优化时间复杂度,

这里要提到一个倍增的算法思想,本质就是预处理记录每个球员传2^i次球后的得分和接到球的人的下标(这里用x^i都无所谓,只是2^i比较好计算),根据数据范围可以知道,这样每个人的求解时间都在O(logk)以内,时间复杂度为O(nlogk)

代码如下

class Solution {
public:
    long long getMaxFunctionValue(vector<int>& receiver, long long k) {
        int n=receiver.size();
        int m=64 - __builtin_clzll(k);//k的二进制长度
        int g[n][m+1];//记录2^i后的接球人的下标
        long long f[n][m+1];//记录2^i后得到的下标和
        for(int i=0;i<n;i++)//初始化
            f[i][0]=g[i][0]=receiver[i];
        //预处理
        for(int i=1;i<m+1;i++){
            for(int j=0;j<n;j++){
                g[j][i]=g[g[j][i-1]][i-1];
                f[j][i]=f[j][i-1]+f[g[j][i-1]][i-1];
            }
        }
        long long ans=0;
        for(int i=0;i<n;i++){
            long long res=i;
            for(int j=0,node=i;j<m+1;j++){
                if((k>>j)&1){
                    res+=f[node][j];
                    node=g[node][j];
                }  
            }
            ans=max(ans,res);
        }
        return ans;
    }
};

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

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

相关文章

bazel外部依赖管理

前面我们主要分析了基于 Action 的增量构建&#xff0c;缓存和远程执行机制。现在让我们看看 Bazel 是如何管理外部依赖的。 大部分项目都没法避免引入第三方的依赖项。构建系统通常提供了下载第三方依赖的能力。为了避免重复下载&#xff0c;Bazel 要求在声明外部依赖的时候&…

美客多(mercadolibre)测评下单技术(养号环境搭建详解)

MercadoLibre&#xff08;美客多&#xff09;是拉丁美洲的一个网购平台。该公司为其客户提供电子商务交易的购买&#xff0c;出售&#xff0c;支付和收集机制。目前全球第十大电商市场——巴西是MercadoLibre的主要市场&#xff0c;占据近60%的平台营收&#xff0c;接着是阿根廷…

关于购买AirPods,现在是否为最佳时机?

我们不需要解释你为什么想要AirPods。苹果对真正的无线耳机的采用彻底改变了市场&#xff0c;并从那时起大量销售。你总是在记者、同事和名人的耳朵里看到它们——尤其是在我们这个远程工作和Zoom会议的时代。 真正的问题是&#xff0c;你应该现在就买一个&#xff0c;还是在几…

2024年java面试--多线程(1)

系列文章目录 2024年java面试&#xff08;一&#xff09;–spring篇2024年java面试&#xff08;二&#xff09;–spring篇2024年java面试&#xff08;三&#xff09;–spring篇2024年java面试&#xff08;四&#xff09;–spring篇 文章目录 系列文章目录线程调度线程五种状态…

spring boot项目生成容器并运行

一个安静的周末&#xff0c;shigen又睡懒觉了&#xff0c;上次说的拖延症的惩罚来了&#xff1a;早晚各100个健腹轮练习&#xff0c;早上的已经完成了。今天的文章来的有点晚&#xff0c;但是依旧保持质量。 springboot项目生成容器并运行 背景 将springboot项目打包成jar包&…

2021年03月 C/C++(六级)真题解析#中国电子学会#全国青少年软件编程等级考试

第1题&#xff1a;生日相同 2.0 在一个有180人的大班级中&#xff0c;存在两个人生日相同的概率非常大&#xff0c;现给出每个学生的名字&#xff0c;出生月日。试找出所有生日相同的学生。 时间限制&#xff1a;1000 内存限制&#xff1a;65536 输入 第一行为整数n&#xff0c…

Linux系统中u-boot启动流程分析(详解)

大家好&#xff0c;我是ST小智&#xff0c;今天给大家分享一下&#xff0c;u-boot的启动流程。 今天给大家全面的分析一下u-boot启动流程。整理这篇文章花费时间较长&#xff0c;中间很长时间未更新&#xff0c;希望这篇文章对大家有所帮助。 本章主要是详细的分析一下uboot的…

框架分析(8)-React Native

框架分析&#xff08;8&#xff09;-React Native 专栏介绍React Native特性和优势跨平台开发&#xff1a;热更新原生性能组件化开发第三方库支持社区支持 限制和挑战性能问题第三方库兼容性学习曲线 总结 专栏介绍 link 主要对目前市面上常见的框架进行分析和总结&#xff0c…

Node基础and包管理工具

Node基础 fs 模块 fs 全称为 file system&#xff0c;称之为 文件系统&#xff0c;是 Node.js 中的 内置模块&#xff0c;可以对计算机中的磁盘进行操作。 本章节会介绍如下几个操作&#xff1a; 1. 文件写入 2. 文件读取 3. 文件移动与重命名 4. 文件删除 5. 文件夹操作 6. …

安圭拉变成AI领域的数字金矿?

这个小小的岛国今年的域名销售额可能达到其GDP的10%&#xff01; 安圭拉a小小的英国岛屿领土在加勒比海地区&#xff0c;由于其“可再生能源”&#xff0c;今年可能带来高达3000万美元的收入。ai”域名&#xff0c;报告彭博在周四发表的一篇文章中说。在过去的一年里&#xff0…

应届生面试指南:如何在缺乏经验的情况下脱颖而出

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

IMU姿态计算

总述 IMU即惯性测量单元&#xff0c;主要用于对机体的加速度与角速度的测算&#xff0c;使用场景很多&#xff0c;例如: 平衡车、惯性导航等等 姿态 姿态角&#xff08;Euler angles&#xff09;是用于描述物体在三维空间中的旋转姿态的一种表示方法。它由三个角度组成&…

微机原理 || 第3次测试:第八章-常用接口芯片82558253(测试题+手写解析)

&#xff08;一&#xff09;知识点总结 一直没有学明白8253和8255芯片&#xff0c;觉得后面难&#xff0c;其实看懂后&#xff0c;就是照着表格去对应填写&#xff0c; 知道地址怎么回事就没问题哒~ 相信你&#x1f618; 一、8255芯片&#xff08;不是偷懒&#xff0c;真的就…

PMD代码检查:避免抛出原始的异常类型(AvoidThrowingRawExceptionTypes)

https://docs.pmd-code.org/pmd-doc-6.55.0/pmd_rules_java_design.html#avoidthrowingrawexceptiontypes 避免抛出RuntimeException、Throwable、Exception、Error这样原始的异常类型&#xff0c;而应该抛出它们的子类。 例如下面的使用方法PMD检查报违反项&#xff1a; 在…

动态规划之连续乘积最大子数组 连续和最大子数组

一. 连续和最大子数组 给你一个整数数组 nums &#xff0c;请你找出一个具有最大和的连续子数组&#xff08;子数组最少包含一个元素&#xff09;&#xff0c;返回其最大和。 子数组 是数组中的一个连续部分。 示例 1&#xff1a; 输入&#xff1a;nums [-2,1,-3,4,-1,2,1,-5,…

23062day6

作业&#xff1a;将dict.txt导入到数据库中。 方法1&#xff1a;创建shell脚本&#xff0c; 调用指令创建数据库和表格&#xff0c;使用循环在循环中用数组存储dict.txt的内容并插入表格中。 方法2&#xff1a;在终端创建数据库和表格&#xff0c;将dict.txt中的内容手动输入…

OB Cloud 初体验⎮用户之声

OceanBase 作为国内一款优秀的分布式数据库&#xff0c;这些年来发展很快&#xff0c;在金融、电商、政企、物流等行业得到广泛应用。之前多为私有化部署&#xff0c;去年也推出云版本并于最近进行重大升级。受朋友之约&#xff0c;对其云产品做了个简单测试。因时间所限&#…

Django(10)-项目实战-对发布会管理系统进行测试并获取测试覆盖率

在发布会签到系统中使用django开发了发布会签到系统&#xff0c; 本文对该系统进行测试。 django.test django.test是Django框架中的一个模块&#xff0c;提供了用于编写和运行测试的工具和类。 django.test模块包含了一些用于测试的类和函数&#xff0c;如&#xff1a; Tes…

【算法奥义】最大矩形问题

首先建立一个二维数组&#xff0c;这个二维数组&#xff0c;计算出矩阵的每个元素的左边连续 1 的数量&#xff0c;使用二维数组 left记录&#xff0c;其中left[i][j] 为矩阵第 i 行第 j 列元素的左边连续 1 的数量。 也就是从这个元素开始&#xff0c;从右往左边数有多少个连…

一年一度的苹果秋季发布会7个重要议题需回答,看是否有你关心的

当苹果公司举行产品发布会,比如即将于9月12日举行的苹果活动时,这无疑是该公司向我们介绍其最终展示的产品的来龙去脉的机会。但这也是苹果回答一些紧迫问题的机会,不仅是关于其最新的iPhone、Apple Watch和平板电脑,还有关于其作为一家公司的发展方向。 我们将在9月12日的…