博客
关于我
HDU - 6892 Lunch(SG性质+SG定理)
阅读量:332 次
发布时间:2019-03-04

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

为了解决这个问题,我们需要确定在给定条件下先手是否会赢。这个问题可以通过计算SG值来解决。SG函数用于尼姆博弈,帮助确定局面是否为必胜态或必败态。以下是详细的解决步骤:

分解问题

  • SG函数:SG函数用于尼姆博弈,SG值为0的位置为必败态,否则为必胜态。
  • 质因数分解:每个数的SG值等于其质因数的个数之和。质数的SG值为其本身,合数的SG值为各质因数的SG值之和。
  • 异或结果:计算所有数的SG值的异或结果。如果结果不为0,先手赢,否则先手输。
  • 方法思路

  • 质数表生成:生成一个质数表用于快速分解数。
  • 计算SG值:对于每个数,分解质因数,计算SG值。
  • 异或结果:计算所有数的SG值的异或结果,确定胜负。
  • 解决代码

    import sysimport mathdef compute_SG(n):    if n == 1:        return 0    factors = []    while n % 2 == 0:        factors.append(2)        n = n // 2    i = 3    max_factor = math.sqrt(n)    while i <= max_factor:        while n % i == 0:            factors.append(i)            n = n // i            max_factor = math.sqrt(n)        i += 2    if n > 2:        factors.append(n)    return sum(math.log2(x) for x in factors)def main():    t = int(sys.stdin.readline())    for _ in range(t):        n = int(sys.stdin.readline())        total = 0        for _ in range(n):            num = int(sys.stdin.readline())            sg = compute_SG(num)            total ^= sg        print("W" if total != 0 else "L")if __name__ == "__main__":    main()

    代码解释

  • compute_SG函数:计算给定数的SG值。通过分解质因数,使用对数计算质因数的个数,返回总和。
  • main函数:读取输入,处理每个数,计算SG值并异或结果。最后输出结果,非零为先手赢,零为输。
  • 通过上述方法,我们可以高效确定先手的胜负。

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

    你可能感兴趣的文章
    openlayers 入门教程(十二):定位与轨迹
    查看>>
    openlayers 入门教程(十五):与 canvas、echart,turf 等交互
    查看>>
    openlayers 入门教程(十四):第三方插件
    查看>>
    openlayers 入门教程(四):layers 篇
    查看>>
    OpenLayers 项目分析(三)-OpenLayers中定制JavaScript内置类
    查看>>
    Openlayers中使用Cluster+Overlay实现点击单个要素和聚合要素时显示不同弹窗
    查看>>
    Openlayers中使用Cluster实现点位元素重合时动态聚合与取消聚合
    查看>>
    Openlayers中使用Cluster实现缩放地图时图层聚合与取消聚合
    查看>>
    Openlayers中使用Image的rotation实现车辆定位导航带转角(判断车辆图片旋转角度)
    查看>>
    Openlayers中加载Geoserver切割的EPSG:900913离线瓦片图层组
    查看>>
    Openlayers中多图层遮挡时调整图层上下顺序
    查看>>
    Openlayers中将某个feature置于最上层
    查看>>
    Openlayers中点击地图获取坐标并输出
    查看>>
    Openlayers中设置定时绘制和清理直线图层
    查看>>
    Openlayers图文版实战,vue项目从0到1做基础配置
    查看>>
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers实战:判断共享单车是否在电子围栏内
    查看>>
    Openlayers实战:加载Bing地图
    查看>>
    Openlayers实战:绘制图形,导出geojson文件
    查看>>
    Openlayers实战:绘制图形,导出KML文件
    查看>>