给定一个数组arr,先递减然后递增,返回arr中有多少个绝对值不同的数字?
  KRe60ogUm4le 2024年05月31日 30 0

给定一个数组arr,先递减然后递增,返回arr中有多少个绝对值不同的数字?

双指针。左指针最左,符合条件时右移;右指针最右,符合条件时左移。左指针和右指针,谁大谁移动;同样大,都移动。时间复杂度O(N),额外空间复杂度O(1)。

代码用golang编写。代码如下:

package main

import (
    "fmt"
)

func main() {
    arr := []int{-2, -2, -3, -4, -3, -3, -2, -2, 3, 4}
    if true {
        ret := diff1(arr)
        fmt.Println(ret)
    }
    if true {
        ret := diff2(arr)
        fmt.Println(ret)
    }
}

func diff1(arr []int) int {
    set := make(map[int]struct{})
    for _, v := range arr {
        set[v] = struct{}{}
    }
    return len(set)
}

// 时间复杂度O(N),额外空间复杂度O(1)
func diff2(arr []int) int {
    N := len(arr)
    L := 0
    R := N - 1
    count := 0
    leftVal := 0
    rightVal := 0
    for L <= R {
        count++
        leftVal = arr[L]
        rightVal = arr[R]
        if leftVal < rightVal {
            for R >= 0 && arr[R] == rightVal {
                R--
            }
        } else if leftVal > rightVal {
            for L < N && arr[L] == leftVal {
                L++
            }
        } else {
            for L < N && arr[L] == leftVal {
                L++
            }
            for R >= 0 && arr[R] == rightVal {
                R--
            }
        }
    }
    return count
}

执行结果如下:

2021-05-21:给定一个数组arr,先递减然后递增,返回arr中有多少个绝对值不同的数字?

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2024年05月31日 0

暂无评论

推荐阅读
  KRe60ogUm4le   2024年05月31日   30   0   0 算法leetcodepython
  KRe60ogUm4le   2024年05月31日   29   0   0 算法leetcodepython
  KRe60ogUm4le   2024年05月31日   33   0   0 算法python
  KRe60ogUm4le   2024年05月31日   40   0   0 二叉树算法python
KRe60ogUm4le
最新推荐 更多

2024-05-31