美文网首页
[go语言算法] 求两个增序数组的diff

[go语言算法] 求两个增序数组的diff

作者: Ucan先生 | 来源:发表于2019-08-18 21:12 被阅读0次

题目: 给定两个增序如数组 [1,2,2,3,4,5,5] [2,3,4,5,5,5],要求输出[1,2,5] .求求两个数组diff

 package main

import (
    "fmt"
)

func diff(arr1 []int, arr2 []int) []int {
    len1 := len(arr1)
    len2 := len(arr2)
    i := 0
    j := 0
    arrRes := []int{}
    for i < len1 && j < len2 {
        fmt.Println(arr1[i], arr2[j])
        if arr1[i] == arr2[j] {
            i++
            j++
            continue
        } else if arr1[i] > arr2[j] {
            arrRes = append(arrRes, arr2[j])
            j++
        } else {
            arrRes = append(arrRes, arr1[i])
            i++
        }
    }
    if len1 > len2 {
        for ; i < len1; i++ {
            arrRes = append(arrRes, arr1[i])
        }
    }

    if len2 > len1 {
        for ; i < len1; i++ {
            arrRes = append(arrRes, arr2[i])
        }
    }
    return arrRes
}

func main() {
    arr1 := []int{1, 2, 2, 3, 4, 5, 5, 5, 5, 7}
    arr2 := []int{2, 3, 5, 5}
    fmt.Println(diff(arr1, arr2))
}

相关文章

  • [go语言算法] 求两个增序数组的diff

    题目: 给定两个增序如数组 [1,2,2,3,4,5,5] [2,3,4,5,5,5],要求输出[1,2,5] ....

  • 【Golang 基础】Go 语言的操作符

    Go 语言的运算符 算术运算符 +:相加; -:相减; *:相乘; /:相除; %:求余; ++:自增; --:自...

  • Go语言切片

    // //Go语言切片 // /* // go语言切片是对数组的抽象 // Go 数组的长度不可改变,在特定场景中...

  • Go语言第3天 - 常用数据类型

    以下内容部分参考自Go语言基础数据类型Go语言中的数组切片:特立独行的可变数组Go语言数据类型-数组Go标准容器之...

  • iOS面试之算法大全

    算法 算法内容如下: 字符串反转 链表反转 有序数组合并 Hash算法 查找两个子视图的共同父视图 求无序数组当中...

  • iOS面试之算法模块

    算法 算法内容如下: 字符串反转 链表反转 有序数组合并 Hash算法 查找两个子视图的共同父视图 求无序数组当中...

  • Vue原理「十二」-- vdom和diff算法 *****

    diff 算法概述 diff即对比,是一个广泛的概念,如linux diff、git diff两个JS对象也可以做...

  • 11-Go语言数组和切片-指趣学院

    数组 和C语言一样,Go语言中也有数组的概念, Go语言中的数组也是用于保存一组相同类型的数据 和C语言一样,Go...

  • Golang 学习笔记二 数组、切片

    一、数组 《快学 Go 语言》第 4 课 —— 低调的数组Go 语言里面的数组其实很不常用,这是因为数组是定长的静...

  • 七、Go切片

    七、Go语言切片(Slice) Go 语言切片是对数组的抽象。 Go 数组的长度不可改变,在特定场景中这样的集合就...

网友评论

      本文标题:[go语言算法] 求两个增序数组的diff

      本文链接:https://www.haomeiwen.com/subject/hnpdsctx.html