代码拉取完成,页面将自动刷新
package main
import "fmt"
func merge(nums1 []int, m int, nums2 []int, n int) {
nums1ValIdx, nums2ValIdx := m-1, n-1
setIdx := len(nums1) - 1 //要放入的位置
if nums2ValIdx < 0 {
return
}
for setIdx >= 0 {
// 两种情况
// nums1ValIdx < 0 -> numsValIdx 直接放入nums1中剩下的位置
// nums1ValIdx >= 0 -> 比较大小 放入nums1中setIdx位置
if nums1ValIdx < 0 {
nums1[setIdx] = nums2[nums2ValIdx]
nums2ValIdx--
} else if nums2ValIdx >= 0 {
if nums1[nums1ValIdx] > nums2[nums2ValIdx] {
nums1[setIdx] = nums1[nums1ValIdx]
nums1ValIdx--
} else {
nums1[setIdx] = nums2[nums2ValIdx]
nums2ValIdx--
}
}
setIdx--
}
}
func main() {
baseArr := []int{1, 2, 3, 0, 0, 0}
merge(baseArr, 3, []int{2, 5, 6}, 3)
fmt.Println(baseArr)
baseArr = []int{1}
merge(baseArr, 1, []int{}, 0)
fmt.Println(baseArr)
baseArr = []int{0}
merge(baseArr, 0, []int{1}, 1)
fmt.Println(baseArr)
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。