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

OD统一考试(C卷)

分值: 100分

题目描述

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

输入描述

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

输出描述

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

示例1

输入:
10001

输出:
1

示例2

输入:
0101

输出:
0

备注

1 <= 数组长度 <= 10000

题解

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

C++

cpp 复制代码
#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)

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

相关推荐
转调4 分钟前
每日一练:地下城游戏
开发语言·c++·算法·leetcode
Java探秘者5 分钟前
Maven下载、安装与环境配置详解:从零开始搭建高效Java开发环境
java·开发语言·数据库·spring boot·spring cloud·maven·idea
攸攸太上6 分钟前
Spring Gateway学习
java·后端·学习·spring·微服务·gateway
2301_7869643611 分钟前
3、练习常用的HBase Shell命令+HBase 常用的Java API 及应用实例
java·大数据·数据库·分布式·hbase
2303_8120444614 分钟前
Bean,看到P188没看了与maven
java·开发语言
苹果醋315 分钟前
大模型实战--FastChat一行代码实现部署和各个组件详解
java·运维·spring boot·mysql·nginx
秋夫人17 分钟前
idea 同一个项目不同模块如何设置不同的jdk版本
java·开发语言·intellij-idea
m0_6640470222 分钟前
数字化采购管理革新:全过程数字化采购管理平台的架构与实施
java·招投标系统源码
不穿格子衬衫32 分钟前
常用排序算法(下)
c语言·开发语言·数据结构·算法·排序算法·八大排序
萧鼎38 分钟前
Python调试技巧:高效定位与修复问题
服务器·开发语言·python