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

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

在这里插入图片描述

  • 在看题解之前,我的代码是以下这样:
package mainimport ("fmt"
)func main() {fmt.Println(divisibilityArray("998244353", 3))
}func divisibilityArray(word string, m int) []int {result := make([]int, len(word))sum := 0for 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
}

在这里插入图片描述

  • 在运行时,会卡在当前数据上,看逻辑,总觉得没有问题,但会出现如此结果,只好去翻看官解,官方的答案思路如下:
func divisibilityArray(word string, m int) []int {result := make([]int, len(word))sum := 0for 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取模来避免整数溢出,使得算法对于任意长度的输入都是安全的。
  • 因此,第二个方法更健壮,特别是当处理大数或者不确定输入大小时。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网站维护中的风险及应对策略

在现代数字化时代,企业对网站的维护至关重要,但维护期间也存在着风险和潜在威胁。本文将探讨网站维护中可能面临的风险,并提供一些应对策略以降低这些风险对企业的影响。 一、数据泄露: 在网站维护期间,未经适当保护的…

Matplotlib进阶学习:基于Matplotlib实现设置Times New Roman字体

Matplotlib进阶学习:基于Matplotlib实现设置Times New Roman字体 🌈 个人主页:高斯小哥 🔥 高质量专栏:Matplotlib之旅:零基础精通数据可视化、Python基础【高质量合集】、PyTorch零基础入门教程&#x1f4…

渲染农场与并行处理:大规模渲染任务的高效解决方案

随着数字技术与计算机图形学的突飞猛进,大规模渲染任务已成为电影制作、游戏开发、建筑设计以及科学计算等诸多行业的常态化需求。面对这些日益增长的需求,渲染农场与并行处理技术凭借其卓越的效率和精准度,已然成为应对这些挑战的核心高效解…

服务器上的cuda使用

文章目录 cuda、NVIDIA driver的关系显卡、驱动版本和cuda版本的对应关系常见问题回答cuda驱动下载地址 cuda、NVIDIA driver的关系 https://www.zhihu.com/question/444878482 显卡、驱动版本和cuda版本的对应关系 https://blog.csdn.net/qq_58611650/article/details/123…

MVO-CNN-BiLSTM多输入分类预测|多元宇宙优化算法-卷积-双向长短期神经网络分类预测(Matlab)

目录 一、程序及算法内容介绍: 基本内容: 亮点与优势: 二、实际运行效果: 三、算法介绍: 四、完整程序下载: 一、程序及算法内容介绍: 基本内容: 本代码基于Matlab平台编译&am…

三八妇女节特辑:盘点动画界的女性力量

每年的三八妇女节,都是向全球女性致敬的日子。而在动画界,女性角色们同样展现了她们无与伦比的魅力与力量。今天,我们就来盘点一下国漫中那些优秀而有力量的女性角色。 一、《秦时明月》——赤练 赤练身上的悲剧主要体现在她所经历的命运转折…

处理error: remote origin already exists.及其Gitee文件上传保姆级教程

解决error: remote origin already exists.: 删除远程 Git 仓库 git remote rm origin 再添加远程 Git 仓库 git remote add origin (HTTPS) 比如这样: 然后再push过去就ok了 好多人可能还是不熟悉怎么将文件上传 Gitee:我…

5、string容器-构造函数

#include <iostream> using namespace std;void test01 () {string s1; //默认构造const char * str "hello world!";string s2(str);cout << "s2 " << s2 << endl;string s3(s2);cout << "s3 " << s3 …

CVHub | 万字长文带你全面解读视觉大模型(建议收藏!)

本文来源公众号“CVHub”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;万字长文带你全面解读视觉大模型 0 导读 众所周知&#xff0c;视觉系统对于理解和推理视觉场景的组成特性至关重要。这个领域的挑战在于对象之间的复杂关系…

基于rk3568解决gpio阶梯波形(适用于i2c、uart、电平转换)

目录 1、理解GPIO的开漏&#xff08;OD&#xff09;和开集&#xff08;OC&#xff09; 2、查询io寄存器地址及定义 3、配置可调寄存器接口dev/mem author daisy.skye的博客_CSDN博客-嵌入式,Qt,Linux领域博主 daisy.skye_嵌入式,Linux,Qt-CSDN博客daisy.skye擅长嵌入式,Linux,Q…

静图怎么制作gif动图?这个方法你一定要会

Gif动图是一种非常有趣的图片格式&#xff0c;是以短小精炼的方式展示动画效果&#xff0c;在各大社交媒体和聊天应用中大受追捧。那么&#xff0c;想要制作gif动画应该怎么制作呢&#xff1f;这时候&#xff0c;可以使用gif图片制作&#xff08;https://www.gif.cn/&#xff0…

sql server使用逗号,分隔保存多个id的一些查询保存

方案一&#xff0c;前后不附加逗号&#xff1a; 方案二&#xff0c;前后附加逗号&#xff1a; 其他保存方案&#xff1a; &#xff08;这里是我做一个程序的商家日期规则搞得&#xff0c;后面再补具体操作&#xff09;&#xff1a; 1,2,3 | 1,2,3 | 1,2,3; 1,2,3 &#xff1…