华为机试 - 日志首次上报最多积分
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));
});

相关内容

热门资讯

原创 真... 乔布斯曾讲过一个企业的底层逻辑:如果你在顶层做了正确的事,底层的结果就会随之而来。 人们关注企业每年...
国内成品油价今晚上涨,加满一箱... 界面新闻记者 | 田鹤琪 国内成品油价迎来“三连涨”。 2月24日,国家发改委发布消息称,自24时...
马斯克设想从月球电磁弹射AI卫... IT之家 2 月 25 日消息,据新华社报道,为更便捷部署专用于人工智能 (AI) 的数据中心卫星网...
马年首涨:中概股破局,A股引领... 在黄金因美元强势而黯然跳水、A股于春节后首个交易日释放出久违的磅礴巨量之际,大洋彼岸的美股市场,第一...
原创 帮... 昨晚大宗商品市场,走出一场“分道扬镳”的戏码。 原油连续第三天下跌,WTI跌破66美元,布伦特收在7...
今起可预约!办理2025年度个... 今起可预约!办理2025年度个税汇算 这些事项要注意 2026-02-25 06:54:50 看看...
原创 天... 年后的天津二手房,马上就要起跑了。 其实在1月份迹象就已显现。 往年的楼市淡季却“反常”得活跃:连续...
13F机构追踪:谷歌、拼多多、... 来源:活报告 在美股市场,资产管理规模超过1亿美元的机构需要在每个季度结束后的45天内向SEC提交1...
原创 手... 最近一段时间,有个词突然走红甚至冲上热搜,这就是手搓经济,在这个早已经现代工业化的时代,手搓经济是怎...
【美联储理事警告:美联储货币政... 【美联储理事警告:美联储货币政策可能无法应对AI引发的失业潮 】库克称,AI已引发美国劳动力市场的代...
黄金和交易提醒:金价高位“吞没... 来源:市场资讯 文章来源:汇通财经 周三(2月26日)亚市早盘,现货黄金窄幅震荡,目前交投于5150...
IPO雷达| 百普赛斯港股IP... 百普赛斯(301080.SZ)正式向香港联交所递交招股书。根据公司同步发布的2025年度业绩预告,全...
原创 澳... 2025年一则“澳洲高薪挖角中国稀土团队”的新闻,把全球稀土市场搅得风生水起。澳大利亚莱纳斯公司甩出...
苹果收购单人AI初创公司inv... IT之家 2 月 25 日消息,据 MacRumors 报道,一份提交给欧盟的新文件显示,苹果公司已...
珍惜:由早晨跑步所想到的 我每天早晨起来习惯在校园跑步,在跑步的时候,常常会思考跑步、人生及享受人生之间的关系。 我们知道人的...
趁乱抛售?最高法院刚裁决,对冲... 来源:市场资讯 来源:金十数据 根据外媒获得的一份美国银行报告,花旗的对冲基金客户在上周五美国最高法...
特别关注|9艘!“超高规格”新... 根据广船国际官微介绍,上述MR型油轮新造船为广船国际自主设计,总长约183米、宽32.2米,设计服务...
甲骨文股价在星门项目相关报道发... 来源:环球市场播报 周一, 甲骨文股价下跌4.5%,此前报道称,这家云计算公司与OpenAI和软银的...