2575. 找出字符串的可整除数组(Go语言)

https://leetcode.cn/problems/find-the-divisibility-array-of-a-string/

  • 在看题解之前,我的代码是以下这样:
go 复制代码
package main

import (
	"fmt"
)

func main() {
	fmt.Println(divisibilityArray("998244353", 3))
}

func divisibilityArray(word string, m int) []int {
	result := make([]int, len(word))
	sum := 0
	for i, num := range word {
		sum = sum*10 + int(num-'0')
		//fmt.Println(sum)
		if sum%m == 0 {
			result[i] = 1
		} else {
			result[i] = 0
		}
	}
	return result
}
  • 在运行时,会卡在当前数据上,看逻辑,总觉得没有问题,但会出现如此结果,只好去翻看官解,官方的答案思路如下:
go 复制代码
func divisibilityArray(word string, m int) []int {
	result := make([]int, len(word))
	sum := 0
	for i, num := range word {
		sum = (sum*10 + int(num-'0'))%m
		//fmt.Println(sum)
		if sum == 0 {
			result[i] = 1
		} else {
			result[i] = 0
		}
	}
	return result
}
  • 从代码上看,区别在if里面去%求余和在sum计算时求余的区别,后来在单步执行的时候,猛然发现其中的区别:
  • 第一个代码中,sum在每次循环中都被累加,只有在进行条件判断时才对m取模。这意味着sum的值可能会迅速增长,尤其是当word表示一个非常大的数时。这种方法的缺点是,如果word足够长,就可能导致sum变量溢出(超过Go语言整数类型可以表示的最大值),从而导致错误的结果。
  • 第二个代码中,每次循环迭代都会先计算(sum*10 + int(num-'0')),然后立即对m取模来更新sum。这种方法的优点是sum的值永远不会超过m的值,有效避免了整数溢出的问题,尤其是当处理非常大的数字时。这也意味着即使是非常长的word字符串,这段代码也能正确运行而不会因为整数溢出而失效。

总结

  • 第一个方法在进行模运算之前允许sum增长,可能会在处理非常大的数字时遇到整数溢出问题。
  • 第二个方法通过在每次迭代中立即对m取模来避免整数溢出,使得算法对于任意长度的输入都是安全的。
  • 因此,第二个方法更健壮,特别是当处理大数或者不确定输入大小时。
相关推荐
励志码农19 小时前
JavaWeb 30 天入门:第二十三天 —— 监听器(Listener)
java·开发语言·spring boot·学习·servlet
天高云淡ylz19 小时前
子网掩码的隐形陷阱:为何能ping通却无法HTTPS访问
开发语言·php
汉克老师21 小时前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(5、机甲战士)
c++·算法·蓝桥杯·01背包·蓝桥杯c++·c++蓝桥杯
希望201721 小时前
Golang Panic & Throw & Map/Channel 并发笔记
开发语言·golang
朗迹 - 张伟21 小时前
Golang安装笔记
开发语言·笔记·golang
yzx99101321 小时前
生活在数字世界:一份人人都能看懂的网络安全生存指南
运维·开发语言·网络·人工智能·自动化
小周同学@21 小时前
谈谈对this的理解
开发语言·前端·javascript
Mr_Xuhhh1 天前
项目需求分析(2)
c++·算法·leetcode·log4j
程序员码歌1 天前
明年35岁了,如何破局?说说心里话
android·前端·后端
橙*^O^*安1 天前
Go 语言基础:变量与常量
运维·开发语言·后端·golang·kubernetes