博客
关于我
[bzoj2761][暴力]不重复数字
阅读量:90 次
发布时间:2019-02-26

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

要解决这个问题,我们需要去除一组数中的重复元素,只保留第一次出现的数。以下是具体的解决方案:

方法思路

  • 读取输入数据:首先读取测试用例的数量 T。对于每个测试用例,读取一个整数 N,表示接下来有 N 个数。
  • 去重处理:使用集合来存储已经出现过的数,这样可以快速检查是否已经存在。遍历输入的数,如果数不在集合中,就将其添加到集合中,并记录下来。
  • 输出结果:将保留下来的小数按顺序拼接成字符串,输出结果。
  • 这种方法利用了集合的高效查找和插入特性,确保了在处理大数据量时的性能。

    解决代码

    def main():    import sys    input = sys.stdin.read().split()    ptr = 0    T = int(input[ptr])    ptr += 1    for _ in range(T):        N = int(input[ptr])        ptr += 1        nums = list(map(int, input[ptr:ptr+N]))        ptr += N        seen = set()        res = []        for num in nums:            if num not in seen:                seen.add(num)                res.append(str(num))        print(' '.join(res))if __name__ == "__main__":    main()

    代码解释

  • 读取输入:使用 sys.stdin.read() 读取所有输入数据,并将其拆分成一个列表,处理起来更高效。
  • 处理每个测试用例:读取 T 个测试用例,每个测试用例读取 N 和接下来的 N 个数。
  • 去重处理:使用集合 seen 来记录已经出现的数,遍历输入的数列表,检查是否在集合中,不在的话添加进去,并记录到结果列表中。
  • 输出结果:将结果列表中的数转换为字符串并用空格连接,输出结果。
  • 这种方法确保了在处理大数据量时的高效性和正确性。

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

    你可能感兴趣的文章
    SpringBoot中集成LiteFlow(轻量、快速、稳定可编排的组件式规则引擎)实现复杂业务解耦、动态编排、高可扩展
    查看>>
    P5-js python中的map()函数
    查看>>
    SpringBoot中集成influxdb-java实现连接并操作Windows上安装配置的influxDB(时序数据库)
    查看>>
    P8738 [蓝桥杯 2020 国 C] 天干地支
    查看>>
    PA
    查看>>
    Package Header Cursor
    查看>>
    package,source folder,folder相互转换
    查看>>
    SpringBoot中集成Flyway实现数据库sql版本管理入门以及遇到的那些坑
    查看>>
    package.json文件常用指令说明
    查看>>
    SpringBoot中集成eclipse.paho.client.mqttv3实现mqtt客户端并支持断线重连、线程池高并发改造、存储入库mqsql和redis示例业务流程,附资源下载
    查看>>
    Padding
    查看>>
    paddlehub安装及对口罩检测
    查看>>
    SpringBoot中集成Actuator实现监控系统运行状态
    查看>>
    PaddleSlim 模型量化 源代码解读
    查看>>
    paddle的两阶段基础算法基础
    查看>>
    Page Object模式:为什么它是Web自动化测试的必备工具
    查看>>
    SpringBoot中重写addCorsMapping解决跨域以及提示list them explicitly or consider using “allowedOriginPatterns“ in
    查看>>
    PageHelper 解析及实现原理
    查看>>
    pageHelper分页工具的使用
    查看>>
    pageHelper分页技术
    查看>>