8.23饿了么笔试

第二题: 一个数组的权值是最大值减最小值

给一个数组,你可以切分成若干个子数组,求最大权值和

样例:[1,1,4,3,5] 输出7

from functools import lru_cache
import math
a = [1, 1, 4, 3, 5]
@lru_cache(None)
def dfs(i: int) -> int:
    res = 0
    for j in range(i):
        min_val = min(a[j: i+1])
        max_val = max(a[j: i+1])
        # print(min_val, max_val)
        res = max(res, dfs(j - 1) + max_val - min_val)
        # print(res)
    return res
print(dfs(len(a) - 1))

今晚没参加 自己试了一下可以过第一个样例 #饿了么笔试#
全部评论
Cache要加none吗?
点赞 回复 分享
发布于 2024-09-09 21:02 广东
排序直接减是不是可以
点赞 回复 分享
发布于 2024-08-24 23:01 北京

相关推荐

昨天 16:45
门头沟学院 Java
点赞 评论 收藏
分享
点赞 评论 收藏
分享
06-04 20:17
门头沟学院 Java
牛客713608542号:有的,我今天刚面了一个小厂,他们说刚好有缺人,就放出来了,成都的旅鸽,hxd不如去试试,但是是线下哇,不知道他们支不支持线上,如果有面记得多复习一下sql,我死在这一块上了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务