百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

2025-04-28:替换为数位和以后的最小元素。用go语言,给定一个整

off999 2025-05-22 12:43 13 浏览 0 评论

2025-04-28:替换为数位和以后的最小元素。用go语言,给定一个整数数组 nums,你需要将数组中每个元素替换成该元素各位数字之和。

完成替换后,请返回数组中的最小值。

1 <= nums.length <= 100。

1 <= nums[i] <= 10000。

输入:nums = [999,19,199]。

输出:10。

解释:

nums 替换后变为 [27, 10, 19] ,最小元素为 10 。

题目来自leetcode3300。

详细步骤:

  1. 1. 输入准备
  2. o 接收一个整数数组 nums,数组长度为 1 到 100 之间,数组中每个元素的范围是 1 到 10000。
  3. 2. 初始化变量
  4. o 定义一个变量 minV 用来记录当前计算出的数位和中的最小值。
  5. o 将 minV 初始化为一个很大的整数值(比如系统支持的最大整数),确保后面比较时可以更新。
  6. 3. 遍历数组元素
  7. o 依次访问数组中的每一个元素 num
  8. 4. 计算数位和
  9. o 对当前元素 num,计算其各个位数的数字和。例如,对于 999
  10. o 取最后一位数字 9 累加,
  11. o 再取倒数第二位数字 9 累加,
  12. o 取倒数第三位数字 9 累加,
  13. o 结果为 27。
  14. o 具体做法是通过不断对数字取模 10 (num % 10) 获取个位数,再通过整除 10 (num / 10) 去除最低位,直到数字被处理完。
  15. 5. 更新最小值
  16. o 用刚计算得到的数位和与当前 minV 进行比较。
  17. o 如果该数位和更小,则将其更新为新的 minV
  18. 6. 完成遍历
  19. o 重复步骤 3-5,直到所有元素都完成数位和的计算并比较。
  20. 7. 返回结果
  21. o 返回最终得到的最小数位和 minV
  22. 8. 补充说明
  23. o 题目中提到“将数组中每个元素替换成各位数字之和”,代码虽然没有将数组元素实际修改,但计算过程模拟了替换后的数值计算,最终得到的最小值即为替换后数组中的最小元素。

总时间复杂度分析:

  • o 对于数组中每个元素,都需要计算其数位和。
  • o 每个元素最多有 4 位数字(因为最大值是 10000),
  • o 计算一个元素的数位和是 O(位数),即 O(4) = O(1)(常数时间)。
  • o 数组长度最多为 100。
  • o 因此,遍历整个数组的时间复杂度是 O(n),其中 n 是数组长度。

总体时间复杂度为 O(n)


总额外空间复杂度分析:

  • o 代码中没有使用额外的数组或大规模的数据结构。
  • o 只使用了若干整型变量用于临时存储和比较(如 curminV)等。
  • o 因此,额外空间复杂度为 O(1),即常数空间。

Go完整代码如下:

package main

import (
    "fmt"
    "math"
)

func minElement(nums []int)int {
    minV := math.MaxInt64
    for _, num := range nums {
        cur := 0
        // 计算当前数字的各个位数之和
        for n := num; n > 0; n /= 10 {
            cur += n % 10
        }
        if cur < minV {
            minV = cur
        }
    }
    return minV
}

func main() {
    nums := []int{999, 19, 199}
    result := minElement(nums)
    fmt.Println(result)
}

-

Python完整代码如下:

# -*-coding:utf-8-*-

defmin_element(nums):
    min_v = float('inf')
    for num in nums:
        cur = 0
        n = num
        while n > 0:
            cur += n % 10
            n //= 10
        if cur < min_v:
            min_v = cur
    return min_v

if __name__ == "__main__":
    nums = [999, 19, 199]
    result = min_element(nums)
    print(result)

-


·



我们相信 Go 语言和算法为普通开发者提供了强有力的“面试利器”,并致力于分享全面的编程知识。在这里,您可以找到最新的 Go 语言教程、算法解析、提升面试竞争力的秘籍以及行业动态。


欢迎关注“福大大架构师每日一题”,让 Go 语言和算法助力您的职业发展

·

相关推荐

python pip 命令 参数(python pip命令用不了)

usage:python[option]...[-ccmd|-mmod|file|-][arg]...Options(andcorrespondingenvironm...

Python 包管理:uv 来了!比 pip 快 100 倍的神器,开发者的终极选择?

为什么Python开发者需要uv?Python生态虽繁荣,但包管理一直是痛点:pip安装慢如蜗牛、依赖冲突让人头秃、虚拟环境配置繁琐……直到uv横空出世!这个用Rust语言打造的...

UV:Python包管理的未来已来!比pip快100倍的新选择

引言Python开发者们,是否厌倦了pip的缓慢安装速度?是否希望有一个更快、更现代、更高效的包管理工具?今天,我要向大家介绍一个革命性的Python包管理工具——UV!UV由Rust编写,是pip和...

「Python」 常用的pip命令和Django命令

pip命令如何根据关键词找到PyPI(Python包仓库)上的可用包#方法1:直接访问PyPI官网,输入关键词搜索#方法2#为何不用pipsearchdjango?因为这个命令已不可...

python包管理工具pip freeze详解(python工具包怎么用)

freeze就像其名字表示的意思一样,主要用来以requirement的格式输出已安装的包,这里我们主要讨论以下3个选项:--local、--user、--pathlocal--local选项一般用在...

python包管理工具pip config详解(python的pulp包)

pipconfig主要包含以下子命令:set、get、edit、list、debug、unset。下面我们逐一介绍下它们。pipconfigset这个命令允许我们以name=value的形式配...

pip常用命令,学Python不会这个寸步难行哦(26)

小朋友们好,大朋友们好!我是猫妹,一名爱上Python编程的小学生。欢迎和猫妹一起,趣味学Python。今日主题学习下pip的使用。pip什么是pippip全称PythonPackageIndex...

Python pip 包管理需知(python的包管理)

简介在Python编程中,pip是一个强大且广泛使用的包管理工具。它使我们能够方便地安装、升级和管理Python包。无论是使用第三方库还是分享自己的代码,pip都是我们的得力助手。本文将深入解析pip...

比pip快100倍的Python包安装工具(python如何用pip安装包)

简介uv是一款开源的Python包安装工具,GitHubstar高达56k,以性能极快著称,具有以下特性(官方英文原文):Asingletooltoreplacepip,pip-tool...

Python安装包总报错?这篇解决指南让你告别pip烦恼!

在Python开发中,pip是安装和管理第三方包的必备工具,但你是否经常遇到各种报错,比如无法创建进程、权限不足、版本冲突,甚至SSL证书错误?这些问题不仅浪费时间,还让人抓狂!别担心!本文整理了...

pip vs pipx: Python 包管理器,你选择哪个?

高效的包管理对于Python开发至关重要。pip和pipx是两个最常用的工具。虽然两者都支持安装Python包,但它们的设计和用例却大相径庭。本文将探讨这些差异,解释何时使用每种工具,并...

【python】5分钟掌握pip(包管理)操作

安装一个软件包从庞大的仓库中找到一个库,将其导入您的环境:pipinstallnumpy2.已安装软件包列表调查您领域内存在的库的概要,注意它们的版本:piplist3.升级软件包赋予已安装...

Python pip安装与使用步骤(python的pip安装方法)

安装和使用Python的包管理工具pip是管理Python包和依赖项的基础技能。以下是详细的步骤:安装pip使用系统包管理器安装Windows:通常,安装Python时会自动安装p...

Python自动化办公应用学习笔记3—— pip工具安装

3.1pip工具安装最常用且最高效的Python第三方库安装方式是采用pip工具安装。pip是Python包管理工具,提供了对Python包的查找、下载、安装、卸载的功能。pip是Python官方提...

Python文件压缩神器:ZipFile功能全解析,支持一键压缩和解压

在Python中处理ZIP文件时,zipfile模块是最常用的工具。它提供了创建、读取、修改ZIP文件的完整功能,无需依赖外部命令。本文将通过核心函数、实战案例和避坑指南,带你掌握这个高效的文件处理模...

取消回复欢迎 发表评论: