华为OD机试统一考试 - 找座位

题目描述

在一个大型体育场内举办了一场大型活动,由于疫情防控的需要,要求每位观众的必须间隔至少一个空位才允许落座。

现在给出一排观众座位分布图,座位中存在已落座的观众,请计算出,在不移动现有观众座位的情况下,最多还能坐下多少名观众。

输入描述

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

  • 1 ≤ 数组长度 ≤ 10000

输出描述

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

用例

输入

10001

输出

1

说明

输入

0101

输出

0

说明


import Foundation

func ODTest_8() {
    print("输入描述: 一个数组,用来标识某一排座位中,每个座位是否已经坐人。0表示该座位没有坐人,1表示该座位已经坐人")
    var deskStr = (readLine() ?? "").map { String($0) }
    var count = 0
    for index in 0 ..< deskStr.count {
        if deskStr[index] == "0" {
            let isLeftEmpty = index == 0 || deskStr[index - 1] == "0"
            let isRightEmpty = index == deskStr.count - 1 || deskStr[index + 1] == "0"
            if isLeftEmpty && isRightEmpty {
                count += 1
                deskStr[index] = "1"
            }
        }
    }
    print("输出描述")
    print(count)
}

2024华为OD机试卷题 文章被收录于专栏

本专栏给大家提供了华为2024最新华为OD 题目汇总。华为OD机试刷题记录机考算法题库,帮助你上岸华为。提供C++/Java、JavaScript、Python四种语言的解法。

全部评论

相关推荐

09-13 17:53
已编辑
黑龙江科技大学 iOS开发
题目描述单词接龙的规则是:可用于接龙的单词首字母必须要前一个单词的尾字母相同;当存在多个首字母相同的单词时,取长度最长的单词,如果长度也相等,则取字典序最小的单词;已经参与接龙的单词不能重复使用。现给定一组全部由小写字母组成单词数组,并指定其中的一个单词作为起始单词,进行单词接龙,请输出最长的单词串,单词串是单词拼接而成,中间没有空格。输入描述输入的第一行为一个非负整数,表示起始单词在数组中的索引K,0&nbsp;&lt;=&nbsp;K&nbsp;&lt;&nbsp;N&nbsp;;输入的第二行为一个非负整数,表示单词的个数N;接下来的N行,分别表示单词数组中的单词。输出描述输出一个字符串,表示最终拼接的单词串。补充说明单词个数N的取值范围为[1,&nbsp;20];单个单词的长度的取值范围为[1,&nbsp;30];用例1输入06worddddadcdwordd输出worddwordda说明:先确定起始单词word,再接以d开头的且长度最长的单词dword,剩余以d开头且长度最长的有dd,da,dc,则取字典序最小的da,所以最后输出worddwordda。用例2输入46worddddadcdwordd输出dwordda说明:先确定起始单词word,剩余以d开头且长度最长的有dd,da,dc,则取字典序最小的da,所以最后输出dwordda。解题如下:#include&nbsp;&lt;iostream&gt;#include&nbsp;&lt;vector&gt;#include&nbsp;&lt;string&gt;using&nbsp;namespace&nbsp;std;//&nbsp;判断是否可以接龙bool&nbsp;canChain(const&nbsp;string&amp;amp;&nbsp;a,&nbsp;const&nbsp;string&amp;amp;&nbsp;b)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;a.back()&nbsp;==&nbsp;b.front();}int&nbsp;main()&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;int&nbsp;k,&nbsp;n;&nbsp;&nbsp;&nbsp;&nbsp;cin&nbsp;&gt;&gt;&nbsp;k&nbsp;&gt;&gt;&nbsp;n;&nbsp;&nbsp;&nbsp;&nbsp;vector&lt;string&gt;&nbsp;words(n);&nbsp;&nbsp;//&nbsp;存储单词列表&nbsp;&nbsp;&nbsp;&nbsp;vector&lt;bool&gt;&nbsp;used(n,&nbsp;false);&nbsp;&nbsp;//&nbsp;标记单词是否已经使用过&nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0;&nbsp;i&nbsp;&lt;&nbsp;n;&nbsp;++i)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cin&nbsp;&gt;&gt;&nbsp;words[i];&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;string&nbsp;result&nbsp;=&nbsp;words[k];&nbsp;&nbsp;//&nbsp;结果字符串以起始单词开始&nbsp;&nbsp;&nbsp;&nbsp;used[k]&nbsp;=&nbsp;true;&nbsp;&nbsp;//&nbsp;标记起始单词已使用&nbsp;&nbsp;&nbsp;&nbsp;while&nbsp;(true)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;int&nbsp;nextIndex&nbsp;=&nbsp;-1;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0;&nbsp;i&nbsp;&lt;&nbsp;n;&nbsp;++i)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;找到未使用的单词并且可以接龙&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(!used[i]&nbsp;&amp;amp;&amp;amp;&nbsp;canChain(result,&nbsp;words[i]))&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;如果没有选择单词或者当前单词比选择的单词更长或者相同长度但字典序更小&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(nextIndex&nbsp;==&nbsp;-1&nbsp;||&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;words[i].length()&nbsp;&gt;&nbsp;words[nextIndex].length()&nbsp;||&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(words[i].length()&nbsp;==&nbsp;words[nextIndex].length()&nbsp;&amp;amp;&amp;amp;&nbsp;words[i]&nbsp;&lt;&nbsp;words[nextIndex]))&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;nextIndex&nbsp;=&nbsp;i;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;如果没有找到可以接龙的单词,跳出循环&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(nextIndex&nbsp;==&nbsp;-1)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;break;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;result&nbsp;+=&nbsp;words[nextIndex];&nbsp;&nbsp;//&nbsp;将选择的单词加入结果&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;used[nextIndex]&nbsp;=&nbsp;true;&nbsp;&nbsp;//&nbsp;标记该单词为已使用&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;输出最终拼接的单词串&nbsp;&nbsp;&nbsp;&nbsp;cout&nbsp;&lt;&lt;&nbsp;result&nbsp;&lt;&lt;&nbsp;endl;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;0;}
查看1道真题和解析 投递华为等公司10个岗位
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务