博客
关于我
HDU 5600 N bulbs (BestCoder Round #67 (div.2))
阅读量:633 次
发布时间:2019-03-14

本文共 1033 字,大约阅读时间需要 3 分钟。

为了解决这个问题,我们需要判断熊孩子是否可以从第一个灯泡走到最后一个灯泡,并在过程中将所有灯泡关闭。每经过一个灯泡,熊孩子都会按下开关,改变灯泡的状态。

方法思路

  • 问题分析:熊孩子从第一个灯泡走到最后一个灯泡,每经过一个灯泡都会按下开关,改变灯泡的状态。我们需要确保每个灯泡被按下的次数使其最终关闭。
  • 关键观察:灯泡的状态会根据被按下的次数改变。如果一个灯泡被按下偶数次,状态不变;如果被按下奇数次,状态改变。我们需要确保所有灯泡都被按下偶数次。
  • 连续0段分析:如果一个连续的0段被覆盖奇数次,灯泡会被改变状态,无法保持关闭。因此,我们需要统计所有连续的0段中奇数长度的数量。如果奇数长度的数量是偶数,则可以通过折返法使所有灯泡关闭。
  • 解决代码

    t = int(input())for _ in range(t):    n = int(input())    s = input().strip()    current_zero = 0    count_odd = 0    for c in s:        if c == '0':            current_zero += 1        else:            if current_zero > 0:                if current_zero % 2 == 1:                    count_odd += 1                current_zero = 0    if current_zero > 0:        if current_zero % 2 == 1:            count_odd += 1    print("YES" if count_odd % 2 == 0 else "NO")

    代码解释

  • 读取输入:首先读取测试用例的数量t,然后循环处理每个测试用例。
  • 遍历灯泡状态:对于每个灯泡状态字符串,遍历每个字符,记录当前连续的0的长度和奇数长度段的数量。
  • 统计奇数长度段:每当遇到一个1时,检查当前连续的0的长度,如果为奇数,则增加奇数长度段的数量,并重置当前长度。
  • 处理最后一段:遍历结束后,检查最后一段连续的0的长度,并更新奇数长度段的数量。
  • 判断结果:根据奇数长度段的数量是否为偶数,输出"YES"或"NO"。
  • 这个方法确保了在O(n)时间复杂度内解决问题,适用于大规模输入。

    转载地址:http://bcxoz.baihongyu.com/

    你可能感兴趣的文章
    OpenCV(1)读写图像
    查看>>
    OpenCV:概念、历史、应用场景示例、核心模块、安装配置
    查看>>
    Openlayers Source基础及重点内容讲解
    查看>>
    openlayers 入门教程(八):Geoms 篇
    查看>>
    Openlayers中点击地图获取坐标并输出
    查看>>
    Openlayers图文版实战,vue项目从0到1做基础配置
    查看>>
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
    查看>>
    Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
    查看>>
    Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
    查看>>
    Openlayers高级交互(8/20):选取feature,平移feature
    查看>>
    openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
    查看>>
    OpenLDAP(2.4.3x)服务器搭建及配置说明
    查看>>
    OpenLDAP编译安装及配置
    查看>>
    OpenMCU(一):STM32F407 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>
    OpenMCU(二):GD32E23xx FreeRTOS移植
    查看>>
    OpenMetadata 命令执行漏洞复现(CVE-2024-28255)
    查看>>
    OpenMMLab | S4模型详解:应对长序列建模的有效方法
    查看>>