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

2021-05-21:给定一个数组arr,先递减然后递增,返回arr中有

原创
作者头像
福大大架构师每日一题
修改于 2021-05-22 09:20:17
修改于 2021-05-22 09:20:17
5540
举报

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

福大大 答案2021-05-21:

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

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

代码语言:txt
AI代码解释
复制
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代码

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文