博客
关于我
ny540 奇怪的排序 简单题
阅读量:795 次
发布时间:2023-02-17

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

Bill机器人对自然数的理解与人类不同,它从右往左读数。例如,它会将123理解为321。现在,给定两个数A和B,我们需要生成[A, B]区间中的所有数,并按照Bill的规则排序。

首先,理解Bill的排序规则。Bill从右到左读取数字,导致它对数字的比较基于数字反转后的值。例如,23变成32,15变成51,Bill认为15大于23,因为51 > 32。

接下来,如何模拟Bill的排序?我们需要对每个数字生成反转后的值,并按这些值排序。例如,数字10反转后是01,即1,数字9反转后是9,数字12反转后是21。因此,排序将基于反转后的数值。

解决步骤:

  • 读取输入,获取测试用例数量N。
  • 对于每个测试用例,读取A和B。
  • 生成区间[A, B]的所有数字。
  • 对每个数字生成反转后的键。
  • 根据反转后的键对数字排序。
  • 输出排序后的数字。
  • 编写代码时,需要考虑如何高效生成反转键。由于区间长度最多为51,可以直接生成列表并用反转键排序。

    Python实现:

  • 读取N。
  • 循环读取每个A和B。
  • 生成从A到B的数字列表。
  • 定义函数生成反转键。
  • 排序列表,使用反转键作为排序依据。
  • 输出排序后的数字。
  • 测试样例:输入:28 1522 39区间数字:28, 29, 30, ..., 39反转键:82, 92, 03, 13, 14, ..., 93排序后:10, 8, 9, 11, 12, 13, 14, 1530, 31, 22, 32, 23, 33, 24, 34, 25, 35, 26, 36, 27, 37, 28, 38, 29, 39

    最终代码:

    import sysdef reverse_num(x):    res = 0    while x > 0:        res = res * 10 + x % 10        x = x // 10    return resdef main():    n = int(sys.stdin.readline())    for _ in range(n):        a, b = map(int, sys.stdin.readline().split())        nums = list(range(a, b+1))        nums.sort(key=reverse_num)        print(' '.join(map(str, nums)))if __name__ == "__main__":    main()

    输出:10 8 9 11 12 13 14 1530 31 22 32 23 33 24 34 25 35 26 36 27 37 28 38 29 39

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

    你可能感兴趣的文章
    NutzWk 5.1.5 发布,Java 微服务分布式开发框架
    查看>>
    NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
    查看>>
    NUUO网络视频录像机 upload.php 任意文件上传漏洞复现
    查看>>
    Nuxt Time 使用指南
    查看>>
    NuxtJS 接口转发详解:Nitro 的用法与注意事项
    查看>>
    NVDIMM原理与应用之四:基于pstore 和 ramoops保存Kernel panic日志
    查看>>
    NVelocity标签使用详解
    查看>>
    NVelocity标签设置缓存的解决方案
    查看>>
    Nvidia Cudatoolkit 与 Conda Cudatoolkit
    查看>>
    NVIDIA GPU 的状态信息输出,由 `nvidia-smi` 命令生成
    查看>>
    nvidia 各种卡
    查看>>
    Nvidia 系列显卡大解析 B100、A40、A100、A800、H100、H800、V100 该如何选择,各自的配置详细与架构详细介绍,分别运用于哪些项目场景
    查看>>
    NVIDIA-cuda-cudnn下载地址
    查看>>
    nvidia-htop 使用教程
    查看>>
    nvidia-smi 参数详解
    查看>>
    Nvidia驱动失效,采用官方的方法重装更快
    查看>>
    nvmw安装node-v4.0.0之后版本的临时解决办法
    查看>>
    nvm切换node版本
    查看>>
    nvm安装 出现 Error retrieving “http://xxxx/SHASUMS256.txt“: HTTP Status 404 解决方法
    查看>>
    nvm安装以后,node -v npm 等命令提示不是内部或外部命令 node多版本控制管理 node多版本随意切换
    查看>>