博客
关于我
1010. Pairs of Songs With Total Durations Divisible by 60
阅读量:296 次
发布时间:2019-03-01

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

为了解决这个问题,我们需要找到满足特定条件的歌曲对,使得它们的总时长能被60整除。我们可以通过对每个歌曲的时长取模60来简化问题,并使用哈希表来记录余数出现的次数,从而高效地计算满足条件的对数。

方法思路

  • 问题分析:我们需要找到两个索引i和j,使得i < j且time[i] + time[j]能被60整除。通过对每个元素取模60,我们可以将问题转化为寻找余数对,使得它们的和模60等于0。
  • 哈希表记录:使用哈希表记录每个余数出现的次数。这样,在处理每个余数时,我们可以快速查找所需的余数对。
  • 处理余数对:对于每个余数r,计算需要的余数s = (60 - r) % 60。如果r是0,直接使用当前余数记录的次数;否则,查找s的记录次数,并累加到结果中。
  • 特殊情况处理:当余数为0时,直接累加当前余数的次数,处理所有可能的对数。
  • 解决代码

    from collections import defaultdictdef numPairsDivisibleBy60(time):    record = defaultdict(int)    count = 0    for t in time:        r = t % 60        if r == 0:            count += record[r]        else:            s = 60 - r            count += record.get(s, 0)        record[r] += 1    return count

    代码解释

  • 初始化:使用defaultdict来记录余数出现的次数。
  • 遍历每个时间:对于每个时间t,计算其对60取模的结果r。
  • 处理余数对
    • 如果r为0,直接累加当前余数的次数。
    • 否则,计算所需的余数s,并查找s的次数,累加到结果中。
  • 更新记录:将当前余数r的次数增加1,供下一步处理使用。
  • 这种方法的时间复杂度为O(n),处理每个元素只需常数时间,非常高效。

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

    你可能感兴趣的文章
    NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
    查看>>
    NISP国家信息安全水平考试,收藏这一篇就够了
    查看>>
    NIS服务器的配置过程
    查看>>
    NIS认证管理域中的用户
    查看>>
    Nitrux 3.8 发布!性能全面提升,带来非凡体验
    查看>>
    NiuShop开源商城系统 SQL注入漏洞复现
    查看>>
    NI笔试——大数加法
    查看>>
    NLog 自定义字段 写入 oracle
    查看>>
    NLog类库使用探索——详解配置
    查看>>
    NLP 基于kashgari和BERT实现中文命名实体识别(NER)
    查看>>
    NLP 模型中的偏差和公平性检测
    查看>>
    Vue3.0 性能提升主要是通过哪几方面体现的?
    查看>>
    NLP 项目:维基百科文章爬虫和分类【01】 - 语料库阅读器
    查看>>
    NLP_什么是统计语言模型_条件概率的链式法则_n元统计语言模型_马尔科夫链_数据稀疏(出现了词库中没有的词)_统计语言模型的平滑策略---人工智能工作笔记0035
    查看>>
    NLP、CV 很难入门?IBM 数据科学家带你梳理
    查看>>
    NLP三大特征抽取器:CNN、RNN与Transformer全面解析
    查看>>
    NLP入门(六)pyltp的介绍与使用
    查看>>
    NLP学习笔记:使用 Python 进行NLTK
    查看>>
    NLP度量指标BELU真的完美么?
    查看>>
    NLP的不同研究领域和最新发展的概述
    查看>>