青训营刷题笔记18

一个中等题..

问题描述

小C希望构造一个包含n个元素的数组,且满足以下条件:

  1. 数组中的所有元素两两不同。
  2. 数组所有元素的最大公约数为 k
  3. 数组元素之和尽可能小。

任务是输出该数组元素之和的最小值。


测试样例

样例1:

输入:n = 3 ,k = 1

输出:6

样例2:

输入:n = 2 ,k = 2

输出:6

样例3:

输入:n = 4 ,k = 3

输出:30

解题思路

首先,了解题目给定的要求:

  1. 最大公约数为 k : 这意味着所有的数组元素都必须是 k 的倍数。换句话说,我们可以先将数组元素构造为 k * m 这样的形式,其中 m 是一个正整数。

  2. 元素两两不同 : 数组中的每个元素必须是不同的,因此 m 必须是不同的整数。

  3. 数组元素之和尽可能小 : 我们需要在符合条件的情况下,尽量选择小的整数 m 来构造数组,从而使得数组的和尽可能小。

步骤:
  • 对于给定的 nk,我们需要构造一个数组,数组元素的形式是 k * m,其中 m 是从 1 开始的连续整数,确保元素之间不同。

  • 所以,最小的 n 个满足条件的元素可以选择为:k * 1, k * 2, k * 3, ..., k * n。这样我们得到的数组是 [k*1, k*2, k*3, ..., k*n]

  • 数组元素的和就是这些元素的和,计算方式为:

    根据等差数列求和公式,1 到 n 的和为:

    因此,最终的数组元素之和为:

代码实现

解释

  • solution 函数接收两个参数:nk,分别代表数组的元素个数和最大公约数。
  • 首先计算从 1n 的和(即 1 + 2 + 3 + ... + n),然后乘以 k 得到数组元素之和。
  • main 函数中,我们测试了三个示例用例,分别输出了是否符合预期结果。

复杂度分析

  • 时间复杂度:计算 1n 的和需要常数时间,因此整体时间复杂度为 O(1)
  • 空间复杂度:只用了常数空间,空间复杂度为 O(1)
相关推荐
CoovallyAIHub20 小时前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github
CoovallyAIHub20 小时前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github
CoovallyAIHub21 小时前
OpenClaw:从“19万星标”到“行业封杀”,这只“赛博龙虾”究竟触动了谁的神经?
算法·架构·github
刀法如飞21 小时前
程序员必须知道的核心算法思想
算法·编程开发·算法思想
徐小夕1 天前
pxcharts Ultra V2.3更新:多维表一键导出 PDF,渲染兼容性拉满!
vue.js·算法·github
CoovallyAIHub1 天前
OpenClaw一脚踩碎传统CV?机器终于不再只是看世界
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
仅凭单目相机实现3D锥桶定位?UNet-RKNet破解自动驾驶锥桶检测难题
深度学习·算法·计算机视觉
zone77391 天前
002:RAG 入门-LangChain 读取文本
后端·算法·面试
樱木Plus1 天前
深拷贝(Deep Copy)和浅拷贝(Shallow Copy)
c++