博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
合并两个有序数组的golang实现
阅读量:6290 次
发布时间:2019-06-22

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

给定两个有序整数数组 nums1 和 nums2,将 nums2 合并到 nums1 中,使得 num1 成为一个有序数组。

说明:
  • 初始化 nums1 和 nums2 的元素数量分别为 m 和 n。
  • 你可以假设 nums1 有足够的空间(空间大小大于或等于 m + n)来保存 nums2 中的元素。
输入:nums1 = [1,2,3,0,0,0], m = 3nums2 = [2,5,6],       n = 3输出: [1,2,2,3,5,6]

由题目中我们可以知道其实就是把nums1的前m项和nums2的前n项合并,并放进nums1中

因为nums1要变动,所以我们拷贝nums1到一个临时变量中

//把nums1复制到temp中    temp := make([]int, m)    copy(temp, nums1)

然后就是对比temp与nums2对应的值,比较哪个比较小,小的那个就插入nums1中

t, j := 0, 0 //t为temp的索引,j为nums2的索引    for i := 0; i < len(nums1); i++ {        //比较nums2与temp对应值的大小,小的那个就放进nums1中        if nums2[j] <= temp[t] {            nums1[i] = nums2[j]            j++        } else {            nums1[i] = temp[t]            t++        }    }

但是这样写,总有一个会先用完,当用完的时候,索引++会导致

index out of range

所以要改进一下代码,整体代码:

// 本题的要求是,把nums1的前m项和nums2的前n项合并,放入nums1中。func merge(nums1 []int, m int, nums2 []int, n int) {    //把nums1复制到temp中    temp := make([]int, m)    copy(temp, nums1)    t, j := 0, 0 //t为temp的索引,j为nums2的索引    for i := 0; i < len(nums1); i++ {        //当t大于temp的长度,那就是说temp全部放进去了nums1中,那剩下的就是放nums2剩余的值了        if t >= len(temp) {            nums1[i] = nums2[j]            j++            continue        }        //当j大于nums2的长度的时候,那就是说明nums2全部都放进去了nums1中,那剩下的就是放temp剩余的值了        if j >= n {            nums1[i] = temp[t]            t++            continue        }        //比较nums2与temp对应值的大小,小的那个就放进nums1中        if nums2[j] <= temp[t] {            nums1[i] = nums2[j]            j++        } else {            nums1[i] = temp[t]            t++        }    }    fmt.Println(nums1)}

 

转载于:https://www.cnblogs.com/TimLiuDream/p/10084035.html

你可能感兴趣的文章
同一台电脑上Windows 7和Ubuntu 14.04的CPU温度和GPU温度对比
查看>>
js数组的操作
查看>>
springmvc Could not write content: No serializer
查看>>
Python系语言发展综述
查看>>
新手 开博
查看>>
借助开源工具高效完成Java应用的运行分析
查看>>
163 yum
查看>>
第三章:Shiro的配置——深入浅出学Shiro细粒度权限开发框架
查看>>
80后创业的经验谈(转,朴实但实用!推荐)
查看>>
让Windows图片查看器和windows资源管理器显示WebP格式
查看>>
我的友情链接
查看>>
vim使用点滴
查看>>
embedded linux学习中几个需要明确的概念
查看>>
mysql常用语法
查看>>
Morris ajax
查看>>
【Docker学习笔记(四)】通过Nginx镜像快速搭建静态网站
查看>>
ORA-12514: TNS: 监听程序当前无法识别连接描述符中请求的服务
查看>>
<转>云主机配置OpenStack使用spice的方法
查看>>
java jvm GC 各个区内存参数设置
查看>>
[使用帮助] PHPCMS V9内容模块PC标签调用说明
查看>>