【华为OD题库-008】座位调整-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。考虑数组越界情况:
- 当i-1<0时(i=0),只用考虑arr[i+1]!=1
- 当i+1>=len时(i=len-1),只用考虑arr[i-1]!=1
综上,利用逻辑与短路规则,可以将上述表达式归纳为:
(i == 0 || arr[i - 1] != 1) && (i == n - 1 || arr[i + 1] != 1)
题解
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),查看当前专栏更新的所有题目。
相关文章:
【华为OD题库-008】座位调整-Java
题目 疫情期间课堂的座位进行了特殊的调整,不能出现两个同学紧挨着,必须隔至少一个空位。给你一个整数数组desk表示当前座位的占座情况,由若干0和1组成,其中0表示没有占位,1表示占位。在不改变原有座位秩序情况下&…...
4 Paimon数据湖之Hive Catalog的使用
更多Paimon数据湖内容请关注:https://edu.51cto.com/course/35051.html Paimon提供了两种类型的Catalog:Filesystem Catalog和Hive Catalog。 Filesystem Catalog:会把元数据信息存储到文件系统里面。Hive Catalog:则会把元数据…...
Verilog刷题[hdlbits] :Bcdadd100
题目:Bcdadd100 You are provided with a BCD one-digit adder named bcd_fadd that adds two BCD digits and carry-in, and produces a sum and carry-out. 为您提供了一个名为bcd_fadd的BCD一位数加法器,它将两个BCD数字相加并带入,并生…...
Flink—— Data Source 介绍
Data Source 简介 Flink 做为一款流式计算框架,它可用来做批处理,即处理静态的数据集、历史的数据集;也可以用来做流处理,即实时的处理些实时数据流,实时的产生数据流结果,只要数据源源不断的过来ÿ…...
树之二叉排序树(二叉搜索树)
什么是排序树 说一下普通二叉树可不是左小右大的 插入的新节点是以叶子形式进行插入的 二叉排序树的中序遍历结果是一个升序的序列 下面是两个典型的二叉排序树 二叉排序树的操作 构造树的过程即是对无序序列进行排序的过程。 存储结构 通常采用二叉链表作为存储结构 不能 …...
管易云与电商平台的无代码集成:实现API连接与用户运营
管易云简介及其与电商平台的合作 金蝶管易云是金蝶集团旗下以电商为核心业务的子公司,是国内最早的电商ERP服务商之一,总部在上海,与淘宝、天猫、 京东、拼多多、抖音等300多家主流电商平台建立合作关系,同时管易云是互联网平台首…...
ElementUI的el-upload上传组件与表单一起提交遇到的各种问题以及解决办法(超详细,每个步骤都有详细解读)
背景: 使用ruoyi-vue进行2次开发,需要实现表单与文件上传一起提交,并且文件上传有4个,且文件校验很复杂,因此ruoyi-vue集成的上传组件FileUpload调试几天后发现真不太适用,最终选择element UI原生组件el-upload(FileUpload也是基于el-upload实现的),要实现表单与文件同…...
python flask_restful “message“: “Failed to decode JSON object: None“
1、问题表现 "message": "Failed to decode JSON object: None"2、出现的原因 Werkzeug 版本过高 3、解决方案 pip install Werkzeug2.0解决效果 可以正常显示json数据了 {"message": {"rate": "参数错误"} }...
Linux内核有什么之内存管理子系统有什么第六回 —— 小内存分配(4)
接前一篇文章:Linux内核有什么之内存管理子系统有什么第五回 —— 小内存分配(3) 本文内容参考: linux进程虚拟地址空间 《趣谈Linux操作系统 核心原理篇:第四部分 内存管理—— 刘超》 特此致谢! 二、小…...
【OpenHarmony内核】Harmony内核之线程操作函数(二)
文章目录 前言一、获取线程优先级二、转交控制运行权三、挂起线程3.1 线程的挂起是什么意思?3.2 函数介绍四、恢复线程五、分离指定的线程5.1 分离线程是什么意思5.2 函数介绍六、等待线程终止运行七、终止当前线程的运行八、终止指定线程的运行九、获取活跃线程数总结前言 O…...
二十五、W5100S/W5500+RP2040树莓派Pico<Modebus TCP Server示例>
文章目录 1 前言2 简介2 .1 什么是Modbus TCP?2.2 Modbus TCP指令介绍2.3 请求数据过程2.4 Modbus TCP协议优点2.5 Modbus TCP应用场景 3 WIZnet以太网芯片4 Modbus TCP示例概述以及使用4.1 流程图4.2 准备工作核心4.3 连接方式4.4 主要代码概述4.5 结果演示 5 注意…...
Android画个圆点状态灯
1、创建一个 XML 文件在 res/drawable 目录下(默认为黑色) <?xml version"1.0" encoding"utf-8"?> <shape xmlns:android"http://schemas.android.com/apk/res/android"android:shape"oval"><…...
高性能网络编程 - 解读3种线程模型
文章目录 Pre线程模型1:传统阻塞 I/O 服务模型线程模型2:Reactor 模式Reactor 模式的基本设计思想Reactor 模式中的关键组成3种典型实现单 Reactor 单线程单 Reactor 多线程主从 Reactor 多线程 小结 线程模型3:Proactor 模型 Pre 高性能网络…...
MATLAB中deconvwnr函数用法
目录 语法 说明 示例 使用 Wiener 滤波对图像进行去模糊处理 deconvwnr函数的功能是使用 Wiener 滤波对图像进行去模糊处理。 语法 J deconvwnr(I,psf,nsr) J deconvwnr(I,psf,ncorr,icorr) J deconvwnr(I,psf) 说明 J deconvwnr(I,psf,nsr) 使用 Wiener 滤波算法对…...
赛宁网安入选国家工业信息安全漏洞库(CICSVD)2023年度技术组成员单
近日,由国家工业信息安全发展研究中心、工业信息安全产业发展联盟主办的“2023工业信息安全大会”在北京成功举行。 会上,国家工业信息安全发展研究中心对为国家工业信息安全漏洞库(CICSVD)提供技术支持的单位授牌表彰。北京赛宁…...
Git系列之Git集成开发工具及git扩展使用
🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是君易--鑨,一个在CSDN分享笔记的博主。📚📚 🌟推荐给大家我的博客专栏《Git实战开发》。🎯🎯 &a…...
selenium headless 无头模式慢
selenium设置headlessTrue发现非常慢,headlessFalse要快很多。 最后测试发现升级到selenium最新版本,selenium4.15.2。设置--headlessnew,解决了,速度正常了。 新版selenium有了两种headless模式,参见:He…...
快速修复因相机断电导致视频文件打不开的问题
3-5 本文主要解决因相机突然断电导致拍摄的视频文件打不开的问题。 在日常工作中,有时候需要使用相机拍摄视频,比如现在有不少短视频拍摄的需求,如果因电池突然断电的原因,导致拍出来的视频播放不了,这时候就容易出大…...
Ceph 笔记, ssh写入缓存
硬件建议 — Ceph 文档 写入缓存 企业级 SSD 和 HDD 通常包括断电保护功能,包括 在运行时断电时确保数据耐久性,以及 使用多级缓存来加快直接或同步写入速度。这些设备 可以在两种缓存模式之间切换 -- 刷新到的易失性缓存 具有 fsync 的持久性媒体&a…...
WebSocket魔法师:打造实时应用的无限可能
1、背景 在开发一些前端页面的时候,总是能接收到这样的需求:如何保持页面并实现自动更新数据呢?以往的常规做法,是前端使用定时轮询后端接口,获取响应后重新渲染前端页面,这种做法虽然能达到类似的效果&…...
别再让HAL和RTOS抢Systick了!STM32F4用CubeMX配置FreeRTOS时,改用TIM1做HAL时钟源的保姆级教程
解决STM32F4中HAL与FreeRTOS时钟源冲突的实战指南 在嵌入式开发中,系统时钟的精确性往往决定了整个项目的稳定性。许多开发者在使用STM32CubeMX配置FreeRTOS时,可能都遇到过这样一个警告提示:"强烈建议HAL库使用除Systick以外的时钟源&q…...
MySQL迁移任务中的数据流向监控_使用流量分析工具排查
主从复制流量突增但延迟不涨,大概率是代理或应用直连从库读取、或从库被误写入;INSERT ... SELECT 和 LOAD DATA LOCAL INFILE 会绕过复制监控并放大负载。MySQL主从复制流量突增但延迟不涨,SHOW SLAVE STATUS 看不出问题?这种情况…...
XUnity.AutoTranslator:5分钟实现Unity游戏实时翻译的终极指南
XUnity.AutoTranslator:5分钟实现Unity游戏实时翻译的终极指南 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 还在为看不懂日文、英文或其他语言的Unity游戏而烦恼吗?XUnity.Auto…...
力扣hot100第八题:无重复字符的最长子串python代码实现
第一部分:问题描述 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 示例 1: 输入: s = "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。注意 "bca" 和 "cab" 也是正确答案。…...
如何快速上手NVIDIA Profile Inspector:新手必看的完整显卡优化教程
如何快速上手NVIDIA Profile Inspector:新手必看的完整显卡优化教程 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector 想彻底释放你的NVIDIA显卡性能吗?NVIDIA Profile Inspector正…...
Shared Control【共享控制】- 基于隐式动作学习的辅助机器人直觉化操控
1. 从游戏手柄到机械臂:为什么我们需要共享控制? 想象一下用游戏手柄操控一台工业机械臂的场景。手柄只有两个摇杆和几个按钮,而机械臂可能有7个自由度甚至更多。这种维度不匹配就像让只会说"左转""右转"的人去指挥一个能…...
如何快速掌握Tunny:Go语言终极goroutine池核心组件解析
如何快速掌握Tunny:Go语言终极goroutine池核心组件解析 【免费下载链接】tunny A goroutine pool for Go 项目地址: https://gitcode.com/gh_mirrors/tu/tunny Tunny是一个轻量级的Go语言goroutine池实现,旨在帮助开发者高效管理并发任务。作为Gi…...
QT账号注册踩坑实录:密码要求太奇葩?邮箱验证卡住了?一篇帮你全搞定
QT账号注册全流程避坑指南:从密码设置到邮箱验证的实战解析 第一次接触QT开发环境的新手们,往往会在注册环节遇到各种意想不到的障碍。我清楚地记得自己当初注册QT账号时,反复尝试了五次密码才符合要求,邮箱验证邮件等了半小时都…...
nanobot 源码解析(五):Skills 系统——让 AI 秒变专家
认识Pass层级结构 Pass范围从上到下一共分为5个层级: 模块层级:单个.ll或.bc文件 调用图层级:函数调用的关系。 函数层级:单个函数。 基本块层级:单个代码块。例如C语言中{}括起来的最小代码。 指令层级:单…...
条款04:确定对象被使用前已先被初始化
C并不能保证每个对象在定义时都被自动初始化。就像书中第一条提到的一样,C包含多种子语言,例如定义一个C风格的整型数组(int[])时,其中就可能包含非零初始化的元素,而在定义标准库(STL)中的容器时,例如一个整型向量(st…...
