华为机试 - 日志首次上报最多积分
admin
2024-03-28 08:38:55
0

目录

题目描述

输入描述

输出描述

用例

题目解析

算法源码


题目描述

日志采集是运维系统的的核心组件。日志是按行生成,每行记做一条,由采集系统分批上报。

  • 如果上报太频繁,会对服务端造成压力;
  • 如果上报太晚,会降低用户的体验;
  • 如果一次上报的条数太多,会导致超时失败。

为此,项目组设计了如下的上报策略:

  1. 每成功上报一条日志,奖励1分
  2. 每条日志每延迟上报1秒,扣1分
  3. 积累日志达到100条,必须立即上报

给出日志序列,根据该规则,计算首次上报能获得的最多积分数。

输入描述

按时序产生的日志条数 T1,T2…Tn,其中 1<=n<=1000,0<=Ti<=100

输出描述

首次上报最多能获得的积分数

用例

输入

1 98 1

输出98
说明T1 时刻上报得 1 分
T2 时刻上报得98分,最大
T3 时刻上报得 0 分

题目解析

用例意思是:

如果在T1时刻上报日志,由于只有1条日志,因此可得1分。

如果在T2时刻上报日志,由于T1时刻产生的1条日志延迟了1秒上报,因此要扣1分,到了T2时刻可以上报1+98条日志,可得99分,因此99-1=98分。

如果在T3时刻上报日志,则T1日志延迟了2s,要扣1*2分,T2日志延迟了1s,要扣98*1分,T3时刻可以上报100条日志,可得100分,因此100-2-98=0分。

我的解题思路如下:

这种前后数据具有依赖关系,一般都是用动态规划DP解决。

首先,我用前缀和思路,将每个时刻,可得的正向分计算出来缓存进dp数组中。所谓正向分,比如T2时刻积累了99条日志,那么就应该得到99分。这是正向得分。但是最终得分还需要扣除延迟上报的负向得分。比如T2时刻上报日志的话,则T1时刻产生的每条日志都需要扣除1分,这是负向得分。因此T2时刻的最终得分是:正向得分  - 负向得分 = 99 - 1 = 98分。

计算正向得分时的dp公式为:

dp[0] = arr[0]

dp[i] = arr[i] + dp[i-1]

但是题目中说了,如果积累到100条日志,则必须在那个时刻将所有日志上报,因此dp公式需要修改为:

dp[0] = arr[0]

dp[i] = arr[i] + (dp[i-1] >= 100 ? 0 : dp[i-1])

负向得分的计算:

如果在T1时刻上报的话,无负向得分,即delay[0] = 0

如果在T2时刻上报的话,则负向得分来自于T1时刻, 即 deylay[1] = delay[0] + dp[0] = 0 + 1

如果在T3时刻上报的话,则负向得分来自于T1时刻, 即 deylay[2] = delay[1] + dp[1] = 1 + 99

因此可得 delay[i] = delay[i-1] + dp[i-1]

但是由于当日志满100条时,就必须上报,因此delay应该清零。

即 delay[i] = dp[i-1] >= 100 ? 0 : delay[i-1] + dp[i-1]

算法源码

/* JavaScript Node ACM模式 控制台输入获取 */
const readline = require("readline");const rl = readline.createInterface({input: process.stdin,output: process.stdout,
});rl.on("line", (line) => {const arr = line.split(" ").map(Number);const dp = [arr[0]]; // dp[i]表示:第i时刻可得的正向分const delay = [0]; // delay[i]表示:第i时刻被扣除的负向分const score = [arr[0]]; // score[i]表示:第i时刻最终得分for (let i = 1; i < arr.length; i++) {if (dp[i - 1] < 100) {dp[i] = arr[i] + dp[i - 1];delay[i] = delay[i - 1] + dp[i - 1];} else {dp[i] = arr[i];delay[i] = 0;}score[i] = dp[i] - delay[i];}console.log(Math.max.apply(null, score));
});

相关内容

热门资讯

贷款也“拼团” 银行抢单忙 购物能“拼团”,贷款也能! 近日,一场“拼团融资”的银企对接活动在省工业和信息化厅拉开帷幕。 “贷款...
逛花展、赶市集、嗨直播!202... 5月23日 “2026北京直播电商购物月” 在丰台区丽泽金融商务区·2026北京国际花展 正式拉开帷...
2026中关村毕业季|AI“吃... “上帝会掷骰子吗?” 在联想未来中心的“与智者同场”展区,一位海淀学子对着屏幕问道。 爱因斯坦微微前...
原创 今... 今日为5月23日,国际现货黄金价格在4500美元/盎司整数关口附近徘徊不前,日内最低触及4480美元...
三连亏后变为“无主”状态,农尚... 从吴亮手中接盘农尚环境(300536)不足三年后,林峰如今让出了公司控制权,上市公司进入“无主”状态...
55岁湖南女首富出手!豪掷13... 快科技5月24日消息,与马斯克、库克并肩而坐,刚参加完国宴的湖南女首富周群飞就买了家上市企业。 近日...
外资加仓A股,岂是跟风这么简单... 熬过忙碌的交易日,在周末安静时段,理清接下来布局方向。本篇为大家准备了5条要闻,涵盖市场动态、行业变...
原创 俄... 在全球能源的残酷牌桌上,手里攥着石油,腰杆子才能硬气。长期以来,中东的沙漠、俄罗斯的冰原、美国的页岩...
喜力啤酒有产品将涨价,华润啤酒... 来源:红星新闻 红星资本局5月22日消息,今日,红星资本局从雪花啤酒(厦门)有限公司、华润啤酒方面获...
原创 金... 心理预期调整刻不容缓,五月二十二日,黄金价格或将重现十五年前的历史性低迷。 近期若您密切关注着黄金市...
原创 马... 埃隆·马斯克如果能让SpaceX实现“科幻小说”级别的目标,他可能获得1万亿美元的收入。 埃隆·马斯...
涨涨涨!放开限制、可加杠杆!这... 韩国股市站在风口上! 据最新消息,为吸引更多海外资金进入股市,韩国政府计划放开限制,允许境外投资者直...
下周9家上会丨科创板首单IPO... IPO及再融资上会预告 据交易所官网审核动态信息,下周(5.25-5.29)IPO上会审核6家企业,...
富途、老虎市值蒸发1/4!或被... 来源:金融时报 5月22日,中国证监会宣布依法对Tiger Brokers (NZ) Limited...
马爸爸的好兄弟钱多多搞了杀猪盘... *此图由AI生成 作者| 史大郎&猫哥 来源| 是史大郎&大猫财经Pro 上周四,港股经纬天地大崩盘...
原创 壳... 编辑:XL 国际能源圈最近炸开了锅,壳牌这家百年石油巨头在2026年3月与委内瑞拉政府正式签署多项油...
存储热潮愈演愈烈!奖金拿到手软... 财联社5月24日讯(编辑 卞纯)在席卷全球的存储芯片热潮中,韩国“存储芯片双雄”SK海力士和三星无疑...
揽牌、合作、生态,跨境支付头部... 近日,国内头部跨境支付机构密集落地海外重要布局,一方面,连连数字、PingPong两家公司相继在中东...
原创 帮... 老铁们,周末好!我是帮主郑重。刚扫了一眼下周的财经日历,好家伙,事件一个接一个,堪称“消息面轰炸周”...
海南省住建厅与中国石化海南石油... 5月22日,中国石化海南石油分公司代表、党委书记李新强、总经理蔡文东一行赴海南省住建厅拜访交流。省住...