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 北京

相关推荐

吐泡泡的咸鱼:我也工作了几年了,也陆陆续续面试过不少人,就简历来说,第一眼学历不太够,你只能靠你的实习或者论文或者项目经历,然后你没有论文,没有含金量高的比赛和奖项,只能看实习和项目,实习来说,你写的实习经历完全不清楚你想找什么工作?行研?数据分析?且写的太少了,再看项目,这些项目先不说上过大学读过研究生的都知道很水,然后对你想找的岗位有什么帮助呢?项目和实习也完全不匹配啊,你好像在努力将你所有的经历都放在简历里想表现你的优秀,但是对于你想找的岗位来说,有什么用呢?最后只能获得岗位不匹配的评价。所以你需要明白你想要找的岗位要求是什么,是做什么的,比如产品经理,然后再看你的经历里有什么匹配的上这个岗位,或者对这个岗位以及这个岗位所在的公司有价值,再写到你的简历上
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务