力扣(LeetCode)1753. 移除石子的最大得分(C++\C)

news2024/11/20 4:22:45

贪心+模拟

贪心思路 : 循环从石子数量最多的两堆取石子,直到有两堆以上(含两堆)空石子,维护取子次数,即是答案。贪心的正确性,暂无数学证明。直觉来看,这么做是对的。

CPP

class Solution {
public:
    int maximumScore(int a, int b, int c) {
        int f[3] = {a,b,c};
        sort(f,f+3);
        int ans = 0;
        while(f[0]||f[1]){
            ans++;
            f[1]--,f[2]--;
            sort(f,f+3);
        }
        return ans;
    }
};

C

int cmp(const void *a,const void *b){
    return *(int*)a-*(int*)b;
}
int maximumScore(int a, int b, int c){
    int f[3] = {a,b,c};
    qsort(f,3,sizeof(int),cmp);
    int ans = 0;
    while(f[0]||f[1]){
        ans++;
        f[1]--,f[2]--;
        qsort(f,3,sizeof(int),cmp);
    }
    return ans;
}
  1. 时间复杂度 : O ( m ) O(m) O(m) m m m 是最多石子的那一堆的石子数量, 最坏时间复杂度 O ( m ) O(m) O(m)
  2. 空间复杂度 : O ( 1 ) O(1) O(1) , 只使用常量级空间 。

贪心+数学

a , b , c a,b,c a,b,c 存入数组 f f f 按升序排序。如果 f [ 0 ] + f [ 1 ] < = f [ 2 ] f[0]+f[1]<=f[2] f[0]+f[1]<=f[2] ,根据贪心思路,每次取最大两堆的石子,就是循环从 f [ 2 ] f[2] f[2] m a x ( f [ 0 ] , f [ 1 ] ) max(f[0],f[1]) max(f[0],f[1]) 取石子。取石子的次数 = f [ 0 ] + f [ 1 ] =f[0]+f[1] =f[0]+f[1]

如果 f [ 0 ] + f [ 1 ] > f [ 2 ] f[0]+f[1]>f[2] f[0]+f[1]>f[2] ,可以想象,这种情况一定可以最大限度的取完所有石子——①三堆都取完 ②某一堆剩 1 1 1 个石子,其他两堆取完。根据贪心思路,每次取最大两堆,它的终止条件就是①或②。取石子的次数,只和终止状态下,三堆剩余的石子数有关。我们可以随便取,只要达到①或②的终止状态,就是最优解法。

考虑先从 f [ 2 ] f[2] f[2] m a x ( f [ 0 ] , f [ 1 ] ) max(f[0],f[1]) max(f[0],f[1]) 取石子, f [ 2 ] f[2] f[2] 一定会被取完,因为 f [ 0 ] + f [ 1 ] > f [ 2 ] f[0]+f[1]>f[2] f[0]+f[1]>f[2] 。取完 f [ 2 ] f[2] f[2] 时, f [ 0 ] f[0] f[0] f [ 1 ] f[1] f[1] 的差值不大于 1 1 1 ,接着从 f [ 0 ] f[0] f[0] f [ 1 ] f[1] f[1] 中取石子,最后也能达到三堆都取完或者某一堆剩 1 1 1 个石子,其他两堆取完的状态 。取石子的次数 = ( f [ 0 ] + f [ 1 ] + f [ 2 ] ) ÷ 2 =(f[0]+f[1]+f[2])\div 2 =(f[0]+f[1]+f[2])÷2

CPP

class Solution {
public:
    int maximumScore(int a, int b, int c) {
        int f[3] = {a,b,c};
        sort(f,f+3);
        if(f[0]+f[1]<=f[2]) return f[0] + f[1];
        return f[0]+f[1]+f[2]>>1;
    }
};

C

int cmp(const void *a,const void *b){
    return *(int*)a-*(int*)b;
}
int maximumScore(int a, int b, int c){
    int f[3] = {a,b,c};
    qsort(f,3,sizeof(int),cmp);
    if(f[0]+f[1]<=f[2]) return f[0] + f[1];
    return f[0]+f[1]+f[2]>>1;
}
  1. 时间复杂度 : O ( 1 ) O(1) O(1) , 只进行常量次计算 。
  2. 空间复杂度 : O ( 1 ) O(1) O(1) , 只使用常量级空间 。

AC

AC
AC

致语

  • 理解思路很重要!
  • 欢迎读者在评论区留言,墨染看到就会回复的。

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

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

相关文章

设计模式之观察者模式

Observer design pattern 观察者模式的概念、观察者模式的结构、观察者模式的优缺点、观察者模式的使用场景、观察者模式的实现示例、观察者模式的源码分析 1、观察者模式的概念 观察者模式&#xff0c;又称为发布-订阅模式&#xff0c;即它定义了一种对象间一对多的依赖关系&…

spark 运行自带样例SparkPi、spark-examples报错

报错时我使用的环境如下&#xff1a; windows10中运行&#xff0c;非linux虚拟机 使用微软的Terminal软件进入powershell环境 scala 2.12.10 spark-3.1.1-bin-hadoop3.2 没有单独安装hadoop环境 java 8 注意一&#xff1a;该spark-3.1.1-bin-hadoop3.2在centos 7、树莓派4b官方…

2小时上车AI作画_NovelAI (学会能做游戏mod)

最近在打牌&#xff08;杀戮尖塔真好玩&#xff09;&#xff0c;玩着突发奇想&#xff1a; 能不能&#xff1f;把游戏原画&#xff0c;通过AI作画&#xff0c;替换为二次元风格&#xff1f; 试试就逝逝...简单复盘下 一、部署"NovelAI" 本地部署【需要本地显卡】 …

Linux C 链接模块

静态链接 Linux 下静态库的创建和使用 1.编译静态库源码&#xff1a;gcc -c lib.c -o lib.o 2.生成静态库文件&#xff1a;ar -q lib.a lib.o 2.使用静态库编译&#xff1a;gcc main.c lib.a -o main.out #20-1.c #include <stdio.h>extern char* name(); extern int a…

Python 自动化测试(三): pytest 参数化测试用例构建

在之前的文章中主要分享了 pytest 的实用特性&#xff0c;接下来讲 Pytest 参数化用例的构建。 如果待测试的输入与输出是一组数据&#xff0c;可以把测试数据组织起来用不同的测试数据调用相同的测试方法。参数化顾名思义就是把不同的参数&#xff0c;写到一个集合里&#xff…

Mentor-dft 学习笔记 day46-Graybox OverviewTessent On-Chip Clock Controller(1)

graybox功能简化了分层设计中的扫描插入和ATPG处理过程&#xff0c;允许对子模块执行扫描和ATPG操作&#xff0c;然后允许在以下情况下使用该子模块的简化灰箱表示在下一个更高层次执行扫描和ATPG操作。由于子模块的灰盒表示仅包含最小数量的互连电路&#xff0c;因此在大型分层…

Oracle-在线重定义dbms_redefinition.sync_interim_table增量同步引发TX行锁问题

前言: 近期处理了一起用户使用在线重定义dbms_redefinition增量同步操作引发TX行锁的问题&#xff0c;用户在使用dbms_redefinition.sync_interim_table进行数据增量同步时&#xff0c;在线重定义的原表SQL语句出现了TX行锁等待问题 后面经过分析&#xff0c;发现产生TX行锁问…

短链接业务解决方案(附源码项目)

开源地址 https://github.com/lcy19930619/short-link 一个单节点短链接项目&#xff0c;有需要的拿去改改就行了&#xff0c;如果方便&#xff0c;可以帮忙点点star 什么是短链接 蓝色部分就是短链接 为什么要用短链接&#xff1f; 因为短信是按照字符去计算条数的&#x…

12月21日 OpenCV 实战基础学习笔记——背景建模、光流估计

文章目录前言一、背景建模1、帧差法2、混合高斯模型二、光流估计前言 本文为12月21日 OpenCV 实战基础学习笔记&#xff0c;分为两个章节&#xff1a; 背景建模&#xff1b;光流估计。 一、背景建模 1、帧差法 由于场景中的目标在运动&#xff0c;目标的影像在不同图像帧中…

Redis哨兵机制以及发布订阅

Redis哨兵机制1 哨兵Sentinel机制2 哨兵架构原理3 搭建哨兵架构4 通过springboot操作哨兵Redis发布订阅1 哨兵Sentinel机制 Sentinel&#xff08;哨兵&#xff09;是Redis 的高可用性解决方案&#xff1a;由一个或多个Sentinel 实例组成的Sentinel 系统可以监视任意多个主服务…

海格里斯HEGERLS深度解析|重型四向穿梭车的轨道换向组件及轨道系统

随着自动化仓储物流系统的广泛应用&#xff0c;物流设备也更趋于多样化&#xff0c;比如在货架轨道上可四向行走的穿梭车应运而生&#xff0c;重型四向穿梭车作为一种新型的物流存储设备&#xff0c;通常在轨道平面上有行走方向相互垂直的两个行走系统&#xff0c;通过两个行走…

gRPC学习Go版(一)

文章目录微服务入门gRPC是什么proto 服务定义gRPC 优势gRPC入门简单使用一元RPC服务流RPC客户流RPC双工流RPCgRPC底层原理RPC流长度前缀的消息分帧请求消息响应信息通信模式下的消息流微服务入门 现在的软件很少是一个孤立的单体应用运行的&#xff0c;相反更多是通过互联网连接…

玩以太坊链上项目的必备技能(错误处理以及异常-Solidity之旅十四)

错误处理 作为开发者的我们知道&#xff0c;我们所编写出来的程序难免会出现 bug &#xff0c;而要做的是捕获异常&#xff0c;给用户抛出一个友好地错误提示。 而在 Solidity 中&#xff0c;根据状态恢复异常来处理错误&#xff0c;该异常将撤销在当前调用中对状态所做的所有…

[思维模式-9]:《如何系统思考》-5- 认识篇 - 改变开环、组合逻辑的线性思考,实施闭环、时序逻辑的动态思考。

目录 第1章 因果关系 1.1 因果关系 1.2 因果关系的特点 1.3 因果关系的类型 第2章 线性思考遇到的问题&#xff1a;开环思维、组合逻辑 2.1 开环系统 2.2 组合逻辑 2.3 线性关系 2.4 什么是线性思维&#xff1a;线性因果关系 2.5 线性思维的数学本质 2.6 线性思维的…

自动化药房出药升降机选型设计

一、 运动规划、运动参数的确定 1、 运动参数计算 运动参数主要通过速度规划确定&#xff0c;速度规划采用直线速度特性&#xff0c;如图所示。 运动方程为&#xff1a; 2、 X方向的速度和加速度的估算 已知参数&#xff1a; X方向行程:1…

stream_component_open函数分析

stream_component_open() 函数主要作用是打开 音频流或者视频流 对应的解码器&#xff0c;开启解码线程去解码。 流程图如下&#xff1a; stream_component_open() 的函数定义如下&#xff1a; /* open a given stream. Return 0 if OK */ static int stream_component_open(…

K8S知识点及dashboard操作

1.什么是K8S&#xff1f; K8S是一组服务器集群&#xff0c;可以在集群的各个节点上运行特定的容器。 K8S所管理的是&#xff1a;集群节点上的容器 特性&#xff1a; 自我修复&#xff0c;弹性伸缩&#xff08;根据实时服务器的并打情况&#xff0c;增加或收缩容器数量&…

网络编程套接字Socket(通过两个用例,逐行注释,详细理解)干活满满建议收藏

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录前言1.分类1.流套接字2.数据报套接字3.原始套接字2.Socket通信模型 3.UDP套接字编程1. DatagramSocket API1.构造方法1.DatagramSocket()2.DatagramSocket(int port)…

C语言之复合类型上卷(十八)(阴阳两极)

上一篇: C语言之内存管理&#xff08;十七&#xff09;&#xff08;转世灵童现世&#xff09; 逐梦编程&#xff0c;让中华屹立世界之巅。 简单的事情重复做,重复的事情用心做,用心的事情坚持做&#xff1b; 文章目录前言一、什么是结构体&#xff1f;二、结构体的定义及初始化…

USB TO SPI(上海同旺电子)调试器调试MCP3201 A/D 转换器

所需设备&#xff1a; 1、USB TO SPI(上海同旺电子)&#xff1b; 2、MCP3201 12 位A/D 转换器; 特性 • 12 位分辨率 • 1 LSB DNL &#xff08;最大值&#xff09; • 1 LSB INL &#xff08;最大值&#xff09;&#xff08;MCP3201-B&#xff09; • 2 LSB INL &#xff…