前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >2021-05-21:给定一个数组arr,先递减然后递增,返回arr中有多少个绝对值不同的数字?

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

作者头像
福大大架构师每日一题
发布2021-08-05 15:50:52
6770
发布2021-08-05 15:50:52
举报

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

福大大 答案2021-05-21:

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

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

代码语言:javascript
复制
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
}

执行结果如下:

***

[左神java代码](https://gitee.com/moonfdd/coding-for-great-offer/blob/main/src/class07/Code04_Power2Diffs.java)

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-05-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 福大大架构师每日一题 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档