【华为OD题库-008】座位调整-Java

news/2024/7/20 16:39:51 标签: 华为od, java

题目

疫情期间课堂的座位进行了特殊的调整,不能出现两个同学紧挨着,必须隔至少一个空位。给你一个整数数组desk表示当前座位的占座情况,由若干0和1组成,其中0表示没有占位,1表示占位。在不改变原有座位秩序情况下,还能安排坐几个人?
输入描述:
第一行是一个数组表示作为占座情况,由若干0和1组成,其中0表示没有占位,1表示占位
输出描述:
输出数值表示还能坐几个人
补充说明:
1 <= desk.length <= 2*10^4
示例1
输入:
1,0,0,0,1
输出:
1
说明:
只有desk[2]的位置可以坐一个人

思路

遍历,找出当前为0的位置,如果其前后均不为1,那么此位置可以坐人,将此位置标记为1,结果cnt++;遍历完成后返回cnt即可。
假设当前遍历位置为i,i的范围为[0,len-1],len为数组arr总长度。要让i的前后均不为1,即arr[i-1]!=1&&arr[i+1]!=1。考虑数组越界情况:

  1. 当i-1<0时(i=0),只用考虑arr[i+1]!=1
  2. 当i+1>=len时(i=len-1),只用考虑arr[i-1]!=1

综上,利用逻辑与短路规则,可以将上述表达式归纳为:
(i == 0 || arr[i - 1] != 1) && (i == n - 1 || arr[i + 1] != 1)

题解

java">package hwod;

import java.util.Arrays;
import java.util.Scanner;

public class SeatAjust {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String[] inputs = sc.nextLine().split(",");
        int[] seats = Arrays.stream(inputs).mapToInt(Integer::parseInt).toArray();
        System.out.println(getSeatCnt(seats));
    }

    private static int getSeatCnt(int[] seats) {
        int n = seats.length;
        int cnt = 0;
        for (int i = 0; i < n; i++) {
            if (seats[i] == 0) {
                if ((i == 0 || seats[i - 1] != 1) && (i == n - 1 || seats[i + 1] != 1)) {
                    seats[i] = 1;
                    cnt++;
                }
            }
        }
        return cnt;
    }
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。


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

相关文章

【网络开发必看】聊聊 Tomcat

文章目录 1. 什么是 Tomcat2. 怎么安装 Tomcat3. Tomcat 的目录结构3.1 bin 目录3.2 conf 目录3.3 lib 目录3.4 log 目录3.5 webapps 目录 4. 启动 Tomcat总结 1. 什么是 Tomcat Tomcat 是一个 HTTP 服务器. 前面学习了 HTTP 协议, 知道了 HTTP 协议就是规定 HTTP 客户端和 HT…

[LeetCode]-622. 设计循环队列

目录 662. 设计循环队列 题目 思路 代码 662. 设计循环队列 622. 设计循环队列 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/design-circular-queue/ 题目 设计你的循环队列实现。 循环队列是一种线性数据结构&#xff0c;其操作表现基于 FIFO&…

Snipaste截图工具--------开机后自启动设置

1&#xff0c;找到安装Snipaste的目录&#xff0c;创建快捷方式 2&#xff0c;按winR打开运行框&#xff08;输入shell:startup) 3&#xff0c;将刚才创建的快捷方式拖入此文件夹

人工智能基础——Python:运行效率与时间复杂度

人工智能的学习之路非常漫长&#xff0c;不少人因为学习路线不对或者学习内容不够专业而举步难行。不过别担心&#xff0c;我为大家整理了一份600多G的学习资源&#xff0c;基本上涵盖了人工智能学习的所有内容。点击下方链接,0元进群领取学习资源,让你的学习之路更加顺畅!记得…

【Mongo 实战】——库备份和恢复,指定集合导出和导入

【Mongo 实战】——库备份和恢复&#xff0c;指定集合导出和导入 一.背景 对mongo 的数据存储方式改造&#xff0c;应产品需求的要求&#xff0c;多个片集数据&#xff0c;整合到一个片集。目前线上只有一台机器。 二.mongo 自带的工具 命令关键字作用mongoimport / mongoe…

Hadoop入门——数据分析基本步骤

文章目录 1.概述2.分析步骤2.1第一步 明确分析目的和思路2.2第二步 数据收集2.3第三步 数据处理2.4第四步 数据分析2.5第五步 数据展现2.6第六步 报告撰写 3.总结 1.概述 2.分析步骤 2.1第一步 明确分析目的和思路 2.2第二步 数据收集 2.3第三步 数据处理 2.4第四步 数据分析 …

Vue中的常用指令v-html / v-show / v-if / v-else / v-on / v-bind / v-for / v-model

前言 持续学习总结输出中&#xff0c;Vue中的常用指令v-html / v-show / v-if / v-else / v-on / v-bind / v-for / v-model 概念&#xff1a;指令&#xff08;Directives&#xff09;是Vue提供的带有 v- 前缀 的特殊标签属性。可以提高操作 DOM 的效率。 vue 中的指令按照不…

python中的异常与模块

异常 为了能够让代码可以正常的运行下去&#xff0c;不会因为某个语句而让程序崩溃&#xff0c;所以我们就需要使用异常&#xff0c;异常的语法格式如下&#xff1a; try:可能出现异常的语句 except:出现异常之后的处理同时python也是支持捕获指定异常的 try:可能出现异常的…