前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >2021-08-21:给定一个数组arr,长度为N > 1,从中间切一

2021-08-21:给定一个数组arr,长度为N > 1,从中间切一

原创
作者头像
福大大架构师每日一题
修改2021-08-23 11:17:37
2340
修改2021-08-23 11:17:37
举报

2021-08-21:给定一个数组arr,长度为N > 1,从中间切一刀,保证左部分和右部分都有数字,一共有N-1种切法,如此多的切法中,每一种都有:绝对值(左部分最大值 – 右部分最大值)。返回最大的绝对值是多少?

福大大 答案2021-08-21:

max-arr0和max-arrN-1取最大值。

时间复杂度:O(N)。

空间复杂度:O(1)。

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

代码语言:txt
复制
package main

import (
    "fmt"
    "math"
)

func main() {
    arr := []int{1, 2, 3}
    ret := maxABS3(arr)
    fmt.Println(ret)
}

func maxABS3(arr []int) int {
    max := math.MinInt64
    for i := 0; i < len(arr); i++ {
        max = getMax(arr[i], max)
    }
    return max - getMin(arr[0], arr[len(arr)-1])
}

func getMin(a int, b int) int {
    if a < b {
        return a
    } else {
        return b
    }
}

func getMax(a int, b int) int {
    if a > b {
        return a
    } else {
        return b
    }
}

执行结果如下:

图片
图片

左神java代码

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

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

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

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

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