博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Golang面试考题记录 ━━ 移动零100%务必深刻理解方法三
阅读量:4116 次
发布时间:2019-05-25

本文共 937 字,大约阅读时间需要 3 分钟。

===问:

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

示例:

输入: [0,1,0,3,12]

输出: [1,3,12,0,0]

说明:

  1. 必须在原数组上操作,不能拷贝额外的数组。
  2. 尽量减少操作次数。

===答:

方法一:执行95.84%,内存0%完败

借用一个临时切片,不共享内存地址,结束时替换nums

func moveZeroes1(nums []int) {
l := len(nums) temp := make([]int, l, l) j := 0 for _, v := range nums {
if v != 0 {
temp[j] = v j++ } } nums = append(nums[:0], temp...)}

方法二:执行95.84%,内存0%完败

借用一个临时切片,主要为了循环的时候不影响nums原值

func moveZeroes2(nums []int) {
temp := append([]int{
}, nums...) l := len(nums) i := 0 j := 0 for _, v := range temp {
if v != 0 {
nums[j] = v j++ } else {
i++ nums[l-i] = 0 } }}

方法三:执行100.00%,内存100.00%

连珠串,一个一个地移动,利用索引j记录nums[i]中不为0的值,直到全部替换后再次遇到不为0的值时,则当ij不同时,替换当前i索引的值。

func moveZeroes3(nums []int) {
l := len(nums) j := 0 for i := 0; i < l; i++ {
if nums[i] != 0 {
nums[j] = nums[i] j++ if i > j {
nums[i] = 0 } } }}

===注:

方法三参考了执行效率最高的方案,是一个非常重要的思路,务必深刻理解。

转载地址:http://ktkpi.baihongyu.com/

你可能感兴趣的文章
序列化与自定义序列化
查看>>
ThreadLocal
查看>>
从Executor接口设计看设计模式之最少知识法则
查看>>
OKhttp之Call接口
查看>>
application/x-www-form-urlencoded、multipart/form-data、text/plain
查看>>
关于Content-Length
查看>>
WebRequest post读取源码
查看>>
使用TcpClient可避免HttpWebRequest的常见错误
查看>>
EntityFramework 学习之一 —— 模型概述与环境搭建 .
查看>>
C# 发HTTP请求
查看>>
启动 LocalDB 和连接到 LocalDB
查看>>
Palindrome Number --回文整数
查看>>
Reverse Integer--反转整数
查看>>
Container With Most Water --装最多水的容器(重)
查看>>
Longest Common Prefix -最长公共前缀
查看>>
Letter Combinations of a Phone Number
查看>>
Single Number II --出现一次的数(重)
查看>>
Valid Parentheses --括号匹配
查看>>
Remove Element--原地移除重复元素
查看>>
Remove Duplicates from Sorted Array--从有序数组中移除重复元素
查看>>