博客
关于我
1545 找出第 N 个二进制字符串中的第 K 位(递归)
阅读量:373 次
发布时间:2019-03-04

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

为了解决这个问题,我们需要根据给定的规则生成二进制字符串 Sn,并找到第 k 位的字符。这个问题可以通过递归和镜像方法高效地解决,而无需生成整个字符串。

方法思路

  • 问题分析:

    • 我们生成二进制字符串的规则是:S1 = "0",对于 i > 1,Si = Si-1 + "1" + reverse(invert(Si-1))。
    • 我们需要找到第 k 位的字符,可以是 0 或 1。
  • 关键思路:

    • 中间位置 mid = 1 << (n-1)。如果 k 等于 mid,直接返回 "1"。
    • 如果 k 小于 mid,递归查找前面的字符串。
    • 如果 k 大于 mid,使用镜像方法找到对应的位置,并取反返回结果。
  • 递归方法:

    • 当 k 大于 mid 时,计算左边对应的位置,递归查找并取反结果。
  • 解决代码

    class Solution:    def check(self, c: str):        return "1" if c == "0" else "0"        def findKthBit(self, n: int, k: int) -> str:        if n == 1:            return "0"        mid = 1 << (n - 1)        if k == mid:            return "1"        elif k < mid:            return self.findKthBit(n - 1, k)        else:            pos = (1 << n) - k            return self.check(self.findKthBit(n - 1, pos))

    代码解释

    • check 方法:用于取反字符,0 变为 1,1 变为 0。
    • findKthBit 方法:递归查找第 k 位的字符。
      • 当 n 为 1 时,返回 "0"。
      • 计算中间位置 mid,如果 k 等于 mid,返回 "1"。
      • 如果 k 小于 mid,递归查找前面的字符串。
      • 如果 k 大于 mid,计算对应的左边位置,并递归查找并取反结果。

    这种方法高效且递归,最好时间复杂度为 O(log n),适用于给定的约束条件。

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

    你可能感兴趣的文章
    OpenLayers学习三:地图旋转及地图跳转到某一点的方式(以类为接口)
    查看>>
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers实战:判断共享单车是否在电子围栏内
    查看>>
    Openlayers实战:加载Bing地图
    查看>>
    Openlayers实战:绘制图形,导出geojson文件
    查看>>
    Openlayers实战:绘制图形,导出KML文件
    查看>>
    Openlayers实战:绘制多边形,导出CSV文件
    查看>>
    Openlayers实战:绘制带箭头的线
    查看>>
    Openlayers实战:自定义放大缩小,显示zoom等级
    查看>>
    Openlayers实战:自定义版权属性信息
    查看>>
    Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
    查看>>
    Openlayers实战:选择feature,列表滑动,定位到相应的列表位置
    查看>>
    Openlayers实战:非4326,3857的投影
    查看>>
    Openlayers高级交互(1/20): 控制功能综合展示(版权、坐标显示、放缩、比例尺、测量等)
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
    查看>>
    Openlayers高级交互(12/20):利用高德逆地理编码,点击位置,显示坐标和地址
    查看>>
    Openlayers高级交互(13/20):选择左右两部分的地图内容,横向卷帘
    查看>>
    Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
    查看>>
    Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
    查看>>