博客
关于我
[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/

    你可能感兴趣的文章
    Oracle10g下载地址--多平台下的32位和64位
    查看>>
    Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
    查看>>
    oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
    查看>>
    Oracle11G基本操作
    查看>>
    Oracle11g服务详细介绍及哪些服务是必须开启的?
    查看>>
    Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
    查看>>
    oracle12安装软件后安装数据库,然后需要自己配置监听
    查看>>
    Oracle——08PL/SQL简介,基本程序结构和语句
    查看>>
    Oracle——distinct的用法
    查看>>
    Oracle、MySQL、SQL Server架构大对比
    查看>>
    oracle下的OVER(PARTITION BY)函数介绍
    查看>>
    Oracle中DATE数据相减问题
    查看>>
    Oracle中merge into的使用
    查看>>
    oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
    查看>>
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    Oracle中Transate函数的使用
    查看>>
    oracle中关于日期问题的汇总!
    查看>>
    Oracle中常用的语句
    查看>>
    Oracle中序列的操作以及使用前对序列的初始化
    查看>>
    oracle中新建用户和赋予权限
    查看>>