🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员
✨ 本系列打算持续跟新华为OD-C卷的三语言AC题解
💻 ACM银牌🥈| 多次AK大厂笔试 | 编程一对一辅导
👏 感谢大家的订阅➕ 和 喜欢💗
文章目录
- 前言
- 🎀关于华为OD
- 🧭 机试备考指南
- 🛻 停车场车位统计
- 题目描述
- 输入描述
- 输出描述
- 样例1
- 样例2
- 数据范围
- 题解
- 参考代码
- ✅AC代码截图
前言
🎀关于华为OD
- ✨华为OD的概念
华为的大部分社会招聘采用了被称为OD(Outsourcing Dispatch)模式,这是一种与德科共同进行的招聘方式。在这种模式下,被招聘的员工通常被定级在13至17级,这些员工被视为华为的储备人才。华为每年会从这些OD项目中选拔表现出色的员工,并将他们转为正式员工。 - ⌚️华为 OD 应聘流程
-
第一步:投递简历
- 提供姓名、邮箱、手机号、身份证号,用于锁定,所以投递前需要考虑清楚,投到项目组之后,一般不会转给另一个项目的 HR 了,也就是被锁定。
-
第二步:机试
- 3 道算法题,400 分满分,一般 1 个月的准备时间,华为机试必须要 300 分以上,没有过半年之后才能参加下一次考试。
-
第三步:技术面
- 2 轮技术面试。
-
第四步:HR 与主管面试
-
第五步:录用,发 offer
-
🧭 机试备考指南
-
华为OD的题库大半年跟新一次,也就是说,一旦跟新,那么本年用的题目就是从该题库种选题,大概有100~200道左右
-
最近考试换为C/D卷,C/D卷题库是一样的,D卷为双机位监控,某些外包公司应聘的为D卷。
-
为此清隆帮大家搜集并整理了C卷的题库,后续会由清隆的ACM银牌团队将题目整理后搬上OJ,数据由团队成员精心构造,支持在线评测。
🛻 停车场车位统计
题目描述
K小姐经营着一个特定大小的停车场,停车场可以看成一个数组 c a r s [ ] cars[] cars[],其中 1 1 1 表示有车, 0 0 0 表示没车。现在停车场内停放着大小不一的车辆,其中小车占一个车位(长度 1 1 1),货车占两个车位(长度 2 2 2),卡车占三个车位(长度 3 3 3)。
K小姐想知道,按照当前停车场的停放情况,最少有多少辆车停在停车场内。你能帮帮她吗?
输入描述
输入一个由 0 0 0 和 1 1 1 组成的字符串,以逗号分隔,表示停车场的车位情况。其中 1 1 1 表示有车, 0 0 0 表示没车,字符串长度不超过 1000 1000 1000。
输出描述
输出一个整数,表示停车场内最少的停车数目。
样例1
输入
1,0,1
输出
2
说明: 1 1 1 个小车占第 1 1 1 个车位,第 2 2 2 个车位空, 1 1 1 个小车占第 3 3 3 个车位,最少有 2 2 2 辆车。
样例2
输入
1,1,0,0,1,1,1,0,1
输出
3
说明: 1 1 1 个货车占第 1 1 1、 2 2 2 个车位,第 3 3 3、 4 4 4 个车位空, 1 1 1 个卡车占第 5 5 5、 6 6 6、 7 7 7 个车位,第 8 8 8 个车位空, 1 1 1 个小车占第 9 9 9 个车位,最少有 3 3 3 辆车。
数据范围
1 ≤ c a r s . l e n g t h ≤ 1000 1 \le cars.length \le 1000 1≤cars.length≤1000
题解
本题可以使用贪心算法来解决。我们可以从左到右遍历停车场的车位情况,每次尽可能地停放一辆大的车。
具体地,我们维护一个变量 c n t cnt cnt,表示当前已经停放的车辆数。同时,用变量 i i i 表示当前遍历到的位置。
在遍历过程中,如果当前位置为 0 0 0,说明没有车,直接跳过。如果为 1 1 1,我们就尝试停放一辆车。首先判断能否停放一辆卡车,即 i i i、 i + 1 i+1 i+1、 i + 2 i+2 i+2 这三个位置都为 1 1 1。如果可以,就停一辆卡车, c n t cnt cnt 加 1 1 1, i i i 向后移动 3 3 3 个位置。如果不能停卡车,就判断能否停货车,即 i i i、 i + 1 i+1 i+1 这两个位置都为 1 1 1。如果可以,就停一辆货车, c n t cnt cnt 加 1 1 1, i i i 向后移动 2 2 2 个位置。如果也不能停货车,那只能停一辆小车, c n t cnt cnt 加 1 1 1, i i i 向后移动 1 1 1 个位置。
遍历结束后, c n t cnt cnt 的值就是停车场内最少的停车数目。
参考代码
- Python
cars = input().split(',')
n = len(cars)
cnt = 0
i = 0
while i < n:if cars[i] == '1':if i+2 < n and cars[i+1] == '1' and cars[i+2] == '1':cnt += 1i += 3elif i+1 < n and cars[i+1] == '1':cnt += 1i += 2else:cnt += 1i += 1else:i += 1
print(cnt)
- Java
import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);String[] cars = sc.next().split(",");int n = cars.length;int cnt = 0;for (int i = 0; i < n; ) {if (cars[i].equals("1")) {if (i+2 < n && cars[i+1].equals("1") && cars[i+2].equals("1")) {cnt++;i += 3;} else if (i+1 < n && cars[i+1].equals("1")) {cnt++;i += 2;} else {cnt++;i++;}} else {i++;}}System.out.println(cnt);}
}
- Cpp
#include <iostream>
#include <vector>
#include <string>
#include <sstream>int main() {std::string input;std::getline(std::cin, input);std::istringstream iss(input);std::string car;std::vector<std::string> cars;while (std::getline(iss, car, ',')) {cars.push_back(car);}int n = cars.size();int cnt = 0;int i = 0;while (i < n) {if (cars[i] == "1") {if (i + 2 < n && cars[i + 1] == "1" && cars[i + 2] == "1") {cnt += 1;i += 3;} else if (i + 1 < n && cars[i + 1] == "1") {cnt += 1;i += 2;} else {cnt += 1;i += 1;}} else {i += 1;}}std::cout << cnt << std::endl;return 0;
}
✅AC代码截图
🍓 目前题目还在上传ing,需要抢先体验的联系清隆开通OJ账号,由于维护服务器需要成本💰,所以名额有限(暂不免费啦~)
- Python
- Java
- Cpp