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

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

off999 2025-05-22 12:43 9 浏览 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,这些一定要明白

随着人工智能和大数据的兴起,Python这门语言也被越来越多人使用。为什么python这么火爆呢,一方面是由于其语言的核心设计思想,具备简洁、易读、高效等诸多优点,另一方面是其广泛的应用场景,分别在...

小学生Python编程入门-1.什么是编程?

第一阶段:编程初体验第1章:什么是编程?目标:像探险家发现新大陆一样认识编程!本章将带你解开生活中的“魔法密码”,认识Python的神奇力量,并搭建属于你的第一个魔法基地!1.1生活中的编程案例魔法...

Python报错信息一目了然,3个技巧助你快速定位问题

点赞、收藏、加关注,下次找我不迷路是不是每次看到代码报错就慌得不行?一堆红红绿绿的英文报错信息,看得头都大了,完全不知道从哪儿下手。别担心,今天咱们就来好好聊聊怎么查看Python报错信息,学会...

如何理解Python类中的self?

许多python初学者,在接触到python面向对象的时候,就被类中包含的方法中的self打败了,不知道self是何物?既然写在方法中,是必须参数,为何在调用方法的时候不给它传参数还能正常运行?和我们...

Python简介与开发环境搭建详细教程

1.1Python简介与开发环境搭建详细教程一、Python语言简介1.Python的核心特点2.Python的应用领域表1.1Python主要应用领域领域典型应用常用库Web开发网站后端D...

Python 中 `r` 前缀:字符串处理的“防转义利器”

#Python中`r`前缀:字符串处理的“防转义利器”在Python编程过程中,处理字符串时经常会遇到反斜杠`\`带来的转义问题,而`r`前缀的出现有效解决了这一困扰。它不仅能处理...

Python中去除字符串末尾换行符的方法

技术背景在Python编程中,处理字符串时经常会遇到字符串末尾包含换行符的情况,如从文件中读取每一行内容时,换行符会作为字符串的一部分被读取进来。为了满足后续处理需求,需要将这些换行符去除。实现步骤1...

python利用正则提取字符串中的手机号

需求:利用正则提取字符串中的手机号(假设手机号为1开头的11为数字,要求手机号前后不为数字)待提取的字符串:str="15838477645dfdfdf15887988765dfdf1157...

史上最全正则详解

涉及到处理文本数据时,Python的正则表达式(RegularExpression)提供了一种强大而灵活的工具。下面详细讲解一些常见的正则表达式语法,并提供实例来说明它们的用法。正则表达式语法正则表...

Python正则之glob库

0、glob模块和通配符glob模块最主要的方法有2个:1、glob()2、iglob()以上2种方法一般和通配符一起使用,常用的通配符有3个:*:匹配零个或多个字符...

Python 中 字符串处理的高效方法,不允许你还不知道

以下是Python中字符串处理的高效方法,涵盖常用操作、性能优化技巧和实际应用场景,帮助您写出更简洁、更快速的代码:一、基础高效操作1.字符串拼接:优先用join()代替+原因:join()预...

正则表达式(Regex)在线调试工具-Regex101

前言在字符串查找处理程序中,正则表达式是一个不可忽略的处理方式。我们能够利用正则表达式轻松地做到检索、替换那些符合某个模(规则)的字符串。正则表达式有着很强的灵活性、逻辑性及功能性,可以迅速地用极简...

pandas中使用excel的模糊匹配通配符,真香

前言在pandas中,实现如下的模糊匹配统计,要怎么做?简单:因为在pandas中可以把筛选和统计两种逻辑分开编写,所以代码清晰好用。问题在于pandas中要实现模糊匹配,只能使用正则表达...

5分钟掌握Python(十六)之正则表达式

1)引入re模块:eg:importre#设定一个常量a='两点水|twowater|liangdianshui|草根程序员|ReadingWithU'#正则表达式...

不允许你还不会的Python 文件与字符串处理高效技巧

掌握文件和字符串的高效处理技巧是Python编程中的重要能力。以下是一些专业级的优化技巧和实践方法:一、文件处理高效技巧1.文件读取优化1.1大文件逐行读取#标准方法(内存友好)withop...

取消回复欢迎 发表评论: