每日一题leetcode第2834:找出美丽数组的最小和

目录

一.题目描述

二.思路及优化

三.C++代码


一.题目描述

二.思路及优化

 首先我们看到这个题,就是根据给出的数组元素个数N,从[1,N]找出N个元素,使得N个元素的和最小,其中随便抽两个数出来,两个数之和不能为target。

那我们很自然的就想到,比如N=5,那其最小和肯定是1+2+3+4+5,再给个条件说target=9,那我们会发现一件事情,4和5我们只能有一个,我们肯定舍弃5,拿个6,此时3+6=9,舍弃6,拿进来7,2+7=9,舍弃7,拿8,8+1=9,舍弃8,最后进来9,可以此时最小和是1+2+3+4+9.

根据这个思路我们就可以得到

1.大范围是[1,N]

2.如果我选了一个X在[1,N]中,那么target-x我就不能再选了。如上例:选了1就不能选8,选2就不能有7。最终两个数字慢慢向中间靠齐,得到target/2,我们是一定可以选的(因为target/2会舍弃小数,数往偏小的那边靠一些,更符合我们得到最小和)。

3.在2中我们得到,[1,target/2]我们一定如果选的话一定是最小的,但是如果是N=2,target=6这种情况呢?实际上我们选【1,2】就是最小和了。也就是说我们还需要判断N与target/2的关系。

        (1.)N<=target/2.那我们直接选1到N的元素就可以了,根据等比数列前N项和得到为N(N+1)/2;

        (2)如果N>target/2的话

前target/2个数我们可以选,然后再从target开始选,一直到选取的总个数到N个,即为最小和。

最小和就是 序号1的和:S1=(target/2)*(target/2+1)/2

                   序号2的和: 首先要知道后面有几个数:N-target/2;

                                        那么可选数字就从target到target+(N-target/2)-1;

                                        根据等差数列和的求和公式:

 得到S2=(N-target/2)*(target+target+(N-target/2)-1)/2

        最小和即为S=S1+S2

三.C++代码

题目说了对最后结果要取模,那么其和可能会有点大,我们用long long类型去存数字和;

题目所说模数为10的9次方+7.所以我们直接int mod=1e9+7;

class Solution {
public:int minimumPossibleSum(int n, int target) {int mod = 1e9 + 7;int m = target / 2;if (n <= m) {return (long long) (1 + n) * n / 2 % mod;}return ((long long) (1 + m) * m / 2 + ((long long) target + target + (n - m) - 1) * (n - m) / 2) % mod;}
};

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

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

相关文章

Ubuntu 基本操作-嵌入式 Linux 入门

在 Ubuntu 基本操作 里面基本就分为两部分&#xff1a; 安装 VMware 运行 Ubuntu熟悉 Ubuntu 的各种操作、命令 如果你对 Ubuntu 比较熟悉的话&#xff0c;安装完 VMware 运行 Ubuntu 之后就可以来学习下一章节了。 1. 安装 VMware 运行 Ubuntu 我们首先来看看怎么去安装 V…

百家争鸣!AI艺术生成器的进化: 深入AI生成艺术世界

人工智能&#xff08;AI&#xff09;已经彻底改变了艺术界&#xff0c;AI艺术生成器现在能够创作出独特而迷人的作品。然而&#xff0c;关于AI生成艺术与人类创作艺术的艺术价值的争论仍然在引起争议。 社区对AI生成图像的原创性和所有权提出了关注&#xff0c;导致了法律纠纷和…

诚意满满之讲透事务

诚意满满系列每一篇都是精挑细选&#xff0c;从大众知识点到原理再到具体实现&#xff0c;争取把一个知识点从头到尾完整讲下来&#xff0c;足以应付面试与工作。让读者读完之后能够有一种&#xff1a;“这个知识我看这一篇就够了”的感觉是本系列最大愿望。 对于本人而言&…

Unity 和 OpenCV:结合计算机视觉和游戏开发

文章目录 前言一、Unity 中集成 OpenCV1. 安装OpenCV plus Unity 插件2. 导入 OpenCV 包 二、图像处理应用程序的创建1. 实时轮廓检测2. 粒子发射器3. 碰撞区域 三、效果四、总结 前言 Unity 和 OpenCV 是两个强大的开发工具&#xff0c;分别用于游戏开发和计算机视觉。结合它…

复盘-PPT

调整PPT编号起始页码在设计→幻灯片大小 设置所有以及文本项目符号 ## 打开母版&#xff0c;找到对应级别设置重置 当自动生成的smartart图形不符合预期时

海纳斯Hinas安装Tailscale

海纳斯Hinas安装Tailscale 海纳斯安装Tailscale第一步&#xff0c;注册Tailscale账号&#xff0c;并在手机/电脑安装Tailscale第二步&#xff0c;进入海纳斯后台卸载重装Tailscale 海纳斯安装Tailscale 海纳斯自己安装了Tailscale&#xff0c;但是无法使用&#xff0c;需要卸载…

kibana 上dashbord 和discover 时间快 or 慢 8小时,处理方案

今天遇到了一个问题。在es库中的数据的时间是正确的。但是在kibana的discover展示页面上是错误的&#xff0c;错了8个小时。我这里是快了8个小时。这个问题非常难受&#xff0c;因为看起来&#xff0c;总是差8个小时&#xff0c;特别是查看日志的时候&#xff0c;总有一种错觉&…

【C++初阶】第五站:C/C++内存管理 (匹配使用,干货到位)

前言&#xff1a; 本文知识点&#xff1a; 1. C/C内存分布2. C语言中动态内存管理方式3. C中动态内存管理4. operator new与operator delete函数 5. new和delete的实现原理 &#xff08;干货在此&#xff09; 6. 定位new表达式(placement-new)7. 常见面试题 目录 C/C内…

【环境配置】Linux MySQL8 忘记密码解决措施

本片博客介绍 Linux 操作系统 Ubuntu 下&#xff0c;MySQL8 忘记密码怎么重新设置&#xff0c;笔者亲测有效&#xff0c;分享给大家。 查看 MySQL 版本 $ mysql --version停止 MySQL 服务器&#xff0c;并查看状态是否变更为 Server shutdown complete # 等价命令sudo syste…

EDA软件

EDA软件 EDA概念IC类EDA&#xff08;芯片EDA软件&#xff09;数字芯片和模拟芯片的区别模拟芯片产品种类IC设计类数字电路设计模拟电路设计 IC制造类IC封装类 PCB类EDA&#xff08;板级EDA软件&#xff09;Mentor公司板级EDACadence公司板级EDAAltium公司&#xff08;已被日本瑞…

JavaScript高级Ⅲ

接上文 JavaScript高级Ⅱ JavaScript高级Ⅱ(全面版)-CSDN博客 第3章 正则表达式 3.1 正则表达式 RegExp 对象表示正则表达式&#xff0c;它是对字符串执行模式匹配的强大工具。 3.1.1 创建的方式 方式1&#xff1a; 正则表达式是JS中是一个类&#xff1a;RegExp Regular Exp…

Mysql - is marked as crashed and should be repaired

概述 上周发生了一个Mysql报错的问题&#xff0c;今天有时间整理一下产生的原因和来龙去脉&#xff0c;Mysql的版本是5.5,发生错误的表存储引擎都是MyISAM,产生的报错信息是Table xxxxxx is marked as crashed and should be repaired。 定位问题 产生的后果是Nginx服务没有…