华为上机真题 2022停车场车辆统计

Posted Linux猿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了华为上机真题 2022停车场车辆统计相关的知识,希望对你有一定的参考价值。

🎈 作者:Linux猿

🎈 简介:CSDN博客专家🏆,华为云享专家🏆,Linux、C/C++、云计算、物联网、面试、刷题、算法尽管咨询我,关注我,有问题私聊!

🎈 关注专栏: 数据结构和算法成神路【精讲】优质好文持续更新中……🚀🚀🚀

🎈 欢迎小伙伴们点赞👍、收藏⭐、留言💬


目录

一、题目描述

1.1 输入描述

1.2 输出描述

1.3 测试样例

1.3.1 示例 1

1.3.2 示例 2

二、解题思路

三、代码实现

四、时间复杂度


 注意:题目来源于网络用户分享,本文仅分享做题思路和方法,如有侵权请联系我删除!

一、题目描述

特定大小的停车场,用数组 cars[ ] 表示,其中 1 表示有车,0 表示没车。车辆大小不一,小车占一个车位(长度 1),货车占两个车位(长度 2),卡车占 3 个车位(长度 3 ),统计停车场最少可以停多少辆车,返回具体的数目。

1.1 输入描述

整形字符串数组 cars[ ],其中 1 表示有车,0 表示没车,数组长度小于 1000。

1.2 输出描述

整型数字字符串,表示最少停车数目。

1.3 测试样例

1.3.1 示例 1

输入

1,0,1

输出

2

说明:第一个位置放小车,第三位置放小车。

1.3.2 示例 2

输入

1,1,0,0,1,1,1,0,1

输出

3

说明:第 1,2 个位置停货车,第 5,6,7 个位置停卡车,最后个位置停小车。

二、解题思路

本题比较简单,题目要求是统计最少可以停多少量车,那么,分配车的时候需要先分配卡车,不能放卡车才考虑货车或小车。

按照这个思路:统计连续字符 1 的个数,优先分配卡车,不足的再分配货车或小车,只需要遍历一次即可计算出最少停放的车辆。

三、代码实现

代码实现如下所示。

#include <iostream>

using namespace std;

int main()

    string str;
    while (cin>>str) 
        int num = 0;
        int ans = 0;
        int n = str.size();
        for (int i = 0; i < n; ++i) 
            if (str[i] == '0') 
                if (num) 
                    num = 0;
                    ans++;
                
             else if (str[i] == '1') 
                num++;
                if (num == 3) 
                    num = 0;
                    ans++;
                
            
        
        if (num) ans++;
        cout<<ans<<endl;
    
    return 0;

四、时间复杂度

时间复杂度:O(n)

在上述代码中,n 表示字符串的长度,通过一次 for 循环遍历即可计算出停车的数目。


🎈 感觉有帮助记得「一键三连支持下哦!有问题可在评论区留言💬,感谢大家的一路支持!🤞猿哥将持续输出「优质文章回馈大家!🤞🌹🌹🌹🌹🌹🌹🤞


以上是关于华为上机真题 2022停车场车辆统计的主要内容,如果未能解决你的问题,请参考以下文章

华为机试真题 Java 实现停车场车辆统计

华为上机真题 2022停车场车辆统计

华为OD机试真题Java实现找车位真题+解题思路+代码(2022&2023)

华为OD机试题,用 Java 解停车场车辆统计问题

华为机试真题 Python 实现最多颜色的车辆2022.11 Q4新题

华为机试真题 C++ 实现最多颜色的车辆2022.11 Q4新题