体育场找座位 - 华为OD统一考试(C卷)

news/2024/7/20 18:52:30 标签: 华为od, 算法, python, java, 面试

OD统一考试(C卷)

分值: 100分

alt

题目描述

在一个大型体育场内举办了一场大型活动,由于疫情防控的需要,要求每位观众的必须间隔至少一个空位才允许落座。现在给出一排观众座位分布图,座位中存在已落座的观众,请计算出,在不移动现有观众座位的情况下,最多还能坐下多少名观众。

输入描述

一个数组,用来标识某一排座位中,每个座位是否已经坐人。0表示该座位没有坐人,1表示该座位已经坐人。

输出描述

整数,在不移动现有观众座位的情况下,最多还能坐下多少名观众。

示例1

输入:
10001

输出:
1

示例2

输入:
0101

输出:
0

备注

1 <= 数组长度 <= 10000

题解

通过贪心模拟的方法,遍历座位数组,统计连续的空座位并计算最多还能坐下多少名观众。在每次迭代中,检查当前座位及其相邻座位的状态,如果当前座位为空且两侧也为空,则可坐下一名观众。最后输出结果。

C++

#include <iostream>
#include <vector>

using namespace std;

int main() {
    string seat;
    cin >> seat;

    int result = 0, n = seat.length();

    // pre 用于表示前一个座位的状态, 0表示该座位没有坐人,1表示该座位已经坐人
    char pre = '0';
    for(int i = 0; i < n; i++) {
        // seat[i] 没有人座 且两边都没有人座
        if(pre == '0' && seat[i] == '0' and (i + 1 == n or seat[i+1] == '0')) {
            result++;
            pre = '1';
            continue;
        }
        pre = seat[i];
    }

    cout << result << endl;

    return 0;
}

Java

java">import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String seat = scanner.next();

        int result = 0, n = seat.length();

        // pre 用于表示前一个座位的状态, 0表示该座位没有坐人,1表示该座位已经坐人
        char pre = '0';
        for (int i = 0; i < n; i++) {
            // seat[i] 没有人座 且两边都没有人座
            if (pre == '0' && seat.charAt(i) == '0' && (i + 1 == n || seat.charAt(i + 1) == '0')) {
                result++;
                pre = '1';
                continue;
            }
            pre = seat.charAt(i);
        }

        System.out.println(result);
    }
}

Python

python">seat = input().strip()
result, n = 0, len(seat)

# pre 用于表示前一个座位的状态, 0表示该座位没有坐人,1表示该座位已经坐人
pre = '0'
for i in range(n):
    # seat[i] 没有人座 且两边都没有人座
    if pre == '0' and seat[i] == '0' and (i + 1 == n or seat[i + 1] == '0'):
        result += 1
        pre = '1'
        continue
    pre = seat[i]

print(result)

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏


http://www.niftyadmin.cn/n/5242508.html

相关文章

LVM - 小记

文章目录 Sequential Modeling Enables Scalable Learning for Large Vision Models简介相关工作数据 LVM : Large Vision Models 相关研究&#xff1a; Langding AI : Introducing Domain-Specific Large Vision Models (LVMs) https://www.youtube.com/watch?v29USE4U5IXoL…

二叉树在线OJ

二叉树的构建及遍历 本题目的要求是&#xff1a; 输入一个数组&#xff0c;里面存放了若干个字符&#xff0c;#代表了空指针&#xff0c;数组中的顺序是 是先序遍历&#xff0c;然后要求你用中序输出 首先我们要做的就是构造结构体&#xff1a; typedef struct TreeNode {char…

从0到1 手把手搭建spring cloud alibaba(二十二)neo4j 应用案例大全

介绍 “大数据”每年都在增长,但如今的企业领导者不仅需要管理更大规模的数据,还迫切需要从 现有数据中得出深刻见解。那么,首席信息官和首席技术官应该如何获得这些见解呢? 引用Seth Godin的说法,企业需要摈弃仅仅收集数据点的做法,开始着手建立数据之间的关 联关系。数…

【Python百宝箱】分布式魔法:穿越分布式奇境的导航

Python 交响曲&#xff1a;优雅构建分布式系统的奇妙之旅 前言 随着现代应用程序的发展&#xff0c;分布式系统已经成为应对高负载和复杂任务的关键。在这个领域&#xff0c;Python以其灵活性和强大的生态系统展现出了令人惊叹的实力。本文将带您踏上一场神奇之旅&#xff0c…

[多线程]线程安全问题再讨论 - volatile

目录 1.引言 2.volatil关键字 2.1内存可见性 2.2指令重排序 1.引言 大家好,我是老cu,今天我们来继续聊聊线程安全问题 线程安全是我们在编程开发中遇到的非常常见,棘手 的问题.同时也是多线程部分很复杂的问题.为了线程安全我们要做很多努力.也要对线程安全部分的代码进行慎…

【Pytorch入门】Day3 神经网络

基础 Containers 神经网络的骨架&#xff0c;往里面添加不同的内容&#xff0c;组成神经网络 import torch from torch import nnclass Felix(nn.Module):def __init__(self):super().__init__()def forward(self,input):outputinput1return outputfelixFelix() xtorch.tensor(…

Python读写txt文件数据

&#x1f388; 博主&#xff1a;一只程序猿子 &#x1f388; 博客主页&#xff1a;一只程序猿子 博客主页 &#x1f388; 个人介绍&#xff1a;爱好(bushi)编程&#xff01; &#x1f388; 创作不易&#xff1a;如喜欢麻烦您点个&#x1f44d;或者点个⭐&#xff01; &#x1f…

分包(微信小程序)

首先&#xff0c;微信小程序中使用分包是为了减少首屏的请求&#xff0c;因为微信小程序会默认下载主包内的内容并展示到页面上&#xff0c;但是随着业务量的增加&#xff0c;代码量也会越来越大。会导致我们启动小程序的时候首页加载速度过慢的这个问题。这时我们就可以采用分…