豆包MarsCode算法题:数组元素之和最小化

news2024/11/14 10:45:41

数组元素之和最小化

  • 问题描述
  • 思路分析
    • 分析
    • 思路
    • 解决方案
  • 参考代码(Python)
    • 代码分析
      • 1. `solution` 函数
      • 2. 计算 `1 + 2 + 3 + ... + n` 的和
      • 3. 乘以 `k` 得到最终的数组元素之和
      • 4. 主程序(`if __name__ == '__main__':`)
        • 代码的时间复杂度分析:
        • 代码的空间复杂度分析:

问题描述

在这里插入图片描述

思路分析

分析

  1. 元素两两不同:数组中所有元素必须是不同的。
  2. 元素的最大公约数为 k:所有的元素必须是 k 的倍数。
  3. 元素之和尽可能小:为了让元素的和最小,我们需要尽量选择最小的满足条件的元素。

思路

  • 首先,如果数组元素的最大公约数为 k,那么所有元素可以表示成 k * a1, k * a2, ..., k * an 的形式,其中 a1, a2, ..., ann 个互质的数。
  • 为了满足“元素之和尽可能小”,我们应该选择最小的 n 个互质数,且这些数的公约数为 1。
  • 最小的 n 个互质数依次是:1, 2, 3, …, n。

解决方案

  • 选择最小的 n 个互质数,分别是 1, 2, 3, ..., n
  • 这些数分别乘以 k,得到的数组为 k, 2k, 3k, ..., nk
  • 最终的数组元素之和就是 k * (1 + 2 + 3 + ... + n)

1 + 2 + 3 + ... + n 的和是一个已知公式:n * (n + 1) / 2

因此,数组的最小和就是 k * (n * (n + 1) / 2)

参考代码(Python)

def solution(n: int, k: int) -> int:
    # 计算 1 + 2 + 3 + ... + n 的和
    sum_of_first_n = n * (n + 1) // 2
    # 乘以 k 得到最终的和
    return k * sum_of_first_n

if __name__ == '__main__':
    print(solution(n = 3, k = 1) == 6)  # 1+2+3 = 6
    print(solution(n = 2, k = 2) == 6)  # 2+4 = 6
    print(solution(n = 4, k = 3) == 30) # 3+6+9+12 = 30

代码分析

1. solution 函数

def solution(n: int, k: int) -> int:
  • 功能:该函数的作用是返回一个包含 n 个元素的数组,其满足题目的条件:数组中的元素两两不同,所有元素的最大公约数为 k,并且这些元素之和尽可能小。
  • 参数
    • n: 数组中元素的个数。
    • k: 数组中每个元素的最大公约数。

2. 计算 1 + 2 + 3 + ... + n 的和

sum_of_first_n = n * (n + 1) // 2
  • 解释:为了尽可能使数组元素之和最小,我们选择最小的 n 个互质数,这些数是 1, 2, 3, ..., n

  • 数学公式1 + 2 + 3 + ... + n 的和是一个经典的数学公式:
    在这里插入图片描述

    该公式计算的是从 1 到 n 的所有整数的和。这个公式的时间复杂度是 O(1),只需要常数时间即可计算出结果。

  • 具体实现:使用整数除法 // 来确保计算结果为整数(在 Python 中,/ 默认会返回浮动类型,而我们这里需要整数结果)。

3. 乘以 k 得到最终的数组元素之和

return k * sum_of_first_n
  • 解释:计算完 1 + 2 + 3 + ... + n 的和后,乘以 k 得到数组中所有元素的和。
    • 例如,数组中的元素是 k, 2k, 3k, ..., nk,这些元素的和就是 k * (1 + 2 + 3 + ... + n),即 k 乘以 sum_of_first_n
    • 由于我们已经在前一步计算了 sum_of_first_n,这一步是将它乘以 k 得到最终的结果。

4. 主程序(if __name__ == '__main__':

if __name__ == '__main__':
    print(solution(n = 3, k = 1) == 6)  # 1+2+3 = 6
    print(solution(n = 2, k = 2) == 6)  # 2+4 = 6
    print(solution(n = 4, k = 3) == 30) # 3+6+9+12 = 30
  • 这里的 if __name__ == '__main__': 用来检查该文件是否作为主程序执行。如果是,代码就会运行里面的测试代码;如果这个文件被作为模块导入,里面的测试代码就不会执行。
  • 测试
    • solution(n = 3, k = 1) 返回的是 6,因为选取的是 1, 2, 3,它们的和是 6
    • solution(n = 2, k = 2) 返回的是 6,选取的是 2, 4,它们的和是 6
    • solution(n = 4, k = 3) 返回的是 30,选取的是 3, 6, 9, 12,它们的和是 30
代码的时间复杂度分析:
  • 计算和 1 + 2 + 3 + ... + n:这部分使用了数学公式,时间复杂度是 O(1)。
  • 乘以 k:这只是一个常数乘法操作,时间复杂度也是 O(1)。
  • 总时间复杂度:由于这两个操作的时间复杂度都是 O(1),所以整体时间复杂度是 O(1)。
代码的空间复杂度分析:
  • 该函数只使用了常数空间(除了输入和输出),所以空间复杂度也是 O(1)。

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

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

相关文章

已有账号,重装系统激活office后发现没有ppt,word,excel等

有时候重装系统后,登录windows结果右键没有word,excel等 点击进入office 进入右边的账户 找到设备和订阅 直接下载office 安装后就会出现了

【数据结构与算法】第12课—数据结构之归并排序

文章目录 1. 归并排序2. 计数排序3. 排序算法复杂度及稳定性分析在这里插入图片描述 1. 归并排序 分治法(Divide and Conquer)是一种重要的算法设计策略,其核心思想是将一个复杂的大问题分解为若干个小规模的子问题,递归地解决这些…

shell 100例

1、每天写一个文件 (题目要求) 请按照这样的日期格式(xxxx-xx-xx每日生成一个文件 例如生成的文件为2017-12-20.log,并且把磁盘的使用情况写到到这个文件中不用考虑cron,仅仅写脚本即可 [核心要点] date命令用法 df命令 知识补充&#xff1…

微信公众平台申请(测试平台)

登录平台 微信公众平台 注册信息 回调路径不知道怎么填可以先不填,等写完项目就知道调用那个路径了 这样就注册好了

云原生-docker安装与基础操作

一、云原生 Docker 介绍 Docker 在云原生中的优势 二、docker的安装 三、docker的基础命令 1. docker pull(拉取镜像) 2. docker images(查看本地镜像) 3. docker run(创建并启动容器) 4. docker ps…

Qt 编写插件plugin,支持接口定义信号

https://blog.csdn.net/u014213012/article/details/122434193?spm1001.2014.3001.5506 本教程基于该链接的内容进行升级,在编写插件的基础上,支持接口类定义信号。 环境:Qt5.12.12 MSVC2017 一、创建项目 新建一个子项目便于程序管理【…

社会信任数据 NGO、CGSS、献血量(2000-2021)

非政府组织(NGO)是指在地方、国家或国际级别上组织起来的非营利性的、志愿性的公民组织。在中国,NGO通常被称为民间组织,包括社会团体、民办非企业单位和基金会。 2000年-2021年社会信任数据(NGO、CGSS、献血量&#…

Odoo:免费开源的流程制造行业ERP管理系统

概述 聚焦流程制造连续性生产的特性,提供集成PLMERPMESBI的一体化解决方案,涵盖计划、生产、质量、配方、供销、库存、成本、设备、资金管理等业务领域的整体性解决方案 行业的最新洞察&行业典型痛点 一、生产过程需要精细化控制 需要在各种制约…

D3的竞品有哪些,D3的优势,D3和echarts的对比

D3 的竞品 ECharts: 简介: ECharts 是由百度公司开发的一款开源的 JavaScript 图表库,提供了丰富的图表类型和高度定制化的配置选项。特点: 易于使用,文档详尽,社区活跃,支持多种图表类型(如折线图、柱状图、饼图、散点…

使用nossl模式连接MySQL数据库详解

使用nossl模式连接MySQL数据库详解 摘要一、引言二、nossl模式概述2.1 SSL与nossl模式的区别2.2 选择nossl模式的场景三、在nossl模式下连接MySQL数据库3.1 准备工作3.2 C++代码示例3.3 代码详解3.3.1 初始化MySQL连接对象3.3.2 连接到MySQL数据库3.3.3 执行查询操作3.3.4 处理…

C/C++内存管理 | new的机制 | 重载自己的operator new

一、C/C内存分布 1. 内存分区 栈又叫堆栈–非静态局部变量/函数参数/返回值等等,栈是向下增长的。内存映射段是高效的I/O映射方式,用于装载一个共享的动态内存库。用户可使用系统接口创建共享共享内存,做进程间通信 .堆用于程序运行时动态内…

小面馆叫号取餐流程 佳易王面馆米线店点餐叫号管理系统操作教程

一、概述 【软件资源文件下载在文章最后】 小面馆叫号取餐流程 佳易王面馆米线店点餐叫号管理系统操作教程 点餐软件以其实用的功能和简便的操作,为小型餐饮店提供了高效的点餐管理解决方案,提高了工作效率和服务质量 ‌点餐管理‌:支持电…

单体架构 IM 系统之 Server 节点状态化分析

基于 http 短轮询模式的单体架构的 IM 系统见下图,即客户端通过 http 周期性地轮询访问 server 实现消息的即时通讯,也就是我们前面提到的 “信箱模型”。“信箱模型” 虽然实现非常容易,但是消息的实时性不高。 我们在上一篇文章&#xff08…

大语言模型理论基础

文章目录 前言大语言模型必需知识概述大语言模型目标模型上下文神经网络的神经元常见激活函数SigmoidTanhRelusoftmax 通用近似定理多层感知机(MLP)拟合最后 前言 你好,我是醉墨居士,我们接下来对大语言模型一探究竟,…

37.安卓逆向-壳-smali语法1

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 内容参考于:图灵Python学院 本人写的内容纯属胡编乱造,全都是合成造假,仅仅只是为了娱乐,请不要盲目相信。第一…

Arduino IDE Windows 系统 离线安装 esp32 开发板 亲测好用。

1、前提条件需要具备特殊网络。 2、官方文档地址:Installing - - — Arduino ESP32 latest documentation 3、系统:Windows10 Arduino IDE 版本2.3.3 之前安装的esp32开发板的版本是2.0.13,由于之前没有接触过esp32开发,也没…

使用HTML、CSS和JavaScript创建动态圣诞树

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 ✨特色专栏&#xff1a…

OceanStor Pacific系列 8.1.0 功能架构

功能架构 华为OceanStor Pacific系列提供基于三层的分布式存储架构,融合分布式文件、对象、大数据和块多个服务形态,支持文件、对象、大数据服务部署在一个集群,并统一管理。 华为OceanStor Pacific系列整体功能架构由存储接口层、存储服务…

图像处理实验二(Image Understanding and Basic Processing)

图像理解(Image Understanding)和基本图像处理(Basic Image Processing)是计算机视觉领域的重要组成部分。它们涉及从图像中提取有用信息、分析图像内容、并对其进行处理以达到特定目的。图像理解通常包括识别、分类和解释图像中的…

uniapp 实现tabbar分类导航及滚动联动效果

思路&#xff1a;使用两个scroll-view&#xff0c;tabbar分类导航使用scrollleft移动&#xff0c;内容联动使用页面滚动onPageScroll监听滚动高度 效果图 <template><view class"content" ><view :class"[isSticky ? tab-sticky: ]">…