华为OD机试 - 新员工座位 / 统计友好度最大值 (C++ Java JavaScript Python )

这篇博客介绍了华为OD机考中的一道题目,要求根据工位序列找到友好度最高的空位。友好度定义为空位左右连续老员工数之和。文章提供了输入输出描述、样例以及C++、JavaScript、Java和Python的解题代码。
摘要由CSDN通过智能技术生成

题目描述

工位由序列F1,F2…Fn组成,Fi值为0、1或2。其中0代表空置,1代表有人,2代表障碍物。

1、某一空位的友好度为左右连续老员工数之和,
2、为方便新员工学习求助,优先安排友好度高的空位,

给出工位序列,求所有空位中友好度的最大值

输入描述

第一行为工位序列:F1,F2…Fn组成,
1<=n<=10000,Fi值为0、1或2。其中0代表空置,1代表有人,2代表障碍物。

输出描述

所有空位中友好度的最大值。如果没有空位,返回0。

用例

输入 0 1 0
输出 1
说明 第1个位置和第3个位置,友好度均为1。
输入 1 1 0 1 2 1 0
输出 3
说明 第3个位置友好度为3。因障碍物隔断,左边得2分,右边只能得1分。

题目解析

本题最优解题思路如下:

遍历工位序列,如果当前位置是1,左边连续老员工数加1;如果当前位置是2,左边连续老员工数清零;如果当前位置是0,从当前位置往右遍历,如果右边有老员工,右边连续老员工数加1,否则停止遍历。计算当前空置位置的友好度,更新最大友好度。最后输出所有空位中友好度的最大值

C++

#include <iostream&
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

算法大师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值