0

0

append函数修改底层数组:为什么递归算法中元素会意外被修改?

花韻仙語

花韻仙語

发布时间:2024-11-12 15:04:43

|

883人浏览过

|

来源于php中文网

原创

append函数修改底层数组:为什么递归算法中元素会意外被修改?

避免 append 函数修改底层数组

问题描述:

在利用 append 函数生成数组组合的算法中,发现当输入数组长度大于 5 时,某些元素会受到修改。尽管 append 应为指针传递,并且新声明了 next 数组,但较小的元素会被修改。

问题分析:

问题在于 append 函数的长度追加特性。虽然每次添加元素都会增加容量,但并不是逐个增加,而是以一定的倍数递增。因此,当底层数组被用满时,追加元素会直接申请一个更大的新数组。

示例说明:

以下示例演示了 append 长度追加的过程:

Narration Box
Narration Box

Narration Box是一种语音生成服务,用户可以创建画外音、旁白、有声读物、音频页面、播客等

下载
a := []int{}
for i := 0; i < 10; i++ {
    a = append(a, i)
    fmt.println(cap(a))
}

输出:

1
2
4
4
8
8
8
8
16
16

可以看到,三次 append 增加了 2 个容量,随后直接申请了一个长度为 8 的数组,再往后又申请了一个长度为 16 的数组。

问题算法中的影响:

在问题算法中,插入 [1,2,3] 时生成的底层数组长度为 4。当递归回溯到 [1,2,3] 后面要追加元素 5 时,由于底层数组长度为 4,不必申请新的空间,直接在元数组上修改,导致 [1,2,3,4] 也修改为 [1,2,3,5]。

解决方案:

为新切片强制分配一个新的底层数组即可解决问题:

next := make([]int, len(pre))
copy(next, pre)
next = append(next, (*nums)[i])

相关专题

更多
go语言 数组和切片
go语言 数组和切片

本专题整合了go语言数组和切片的区别与含义,阅读专题下面的文章了解更多详细内容。

45

2025.09.03

append用法
append用法

append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

338

2023.10.25

python中append的用法
python中append的用法

在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

1060

2023.11.14

python中append的含义
python中append的含义

本专题整合了python中append的相关内容,阅读专题下面的文章了解更多详细内容。

167

2025.09.12

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

388

2023.08.14

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

4

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

7

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.6万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号