当前位置: 首页 > news >正文

​力扣解法汇总1010. 总持续时间可被 60 整除的歌曲

目录链接:

力扣编程题-解法汇总_分享+记录-CSDN博客

GitHub同步刷题项目:

https://github.com/September26/java-algorithms

原题链接:

力扣

描述:

在歌曲列表中,第 i 首歌曲的持续时间为 time[i] 秒。

返回其总持续时间(以秒为单位)可被 60 整除的歌曲对的数量。形式上,我们希望下标数字 i 和 j 满足  i < j 且有 (time[i] + time[j]) % 60 == 0

示例 1:

输入:time = [30,20,150,100,40]
输出:3
解释:这三对的总持续时间可被 60 整除:
(time[0] = 30, time[2] = 150): 总持续时间 180
(time[1] = 20, time[3] = 100): 总持续时间 120
(time[1] = 20, time[4] = 40): 总持续时间 60

示例 2:

输入:time = [60,60,60]
输出:3
解释:所有三对的总持续时间都是 120,可以被 60 整除。

提示:

  • 1 <= time.length <= 6 * 104
  • 1 <= time[i] <= 500

描述:

* 解题思路:
* 首先,以和60求余后的结果为key,求每个key的数量。
* 然后遍历数组time,key=i%60,首先当前key的数量减1。
* 如果key=0,则求剩余的数中key=0的数量。
* 如果key>0,则求60-key的数量。

解题思路:

* 解题思路:
* 首先,以和60求余后的结果为key,求每个key的数量。
* 然后遍历数组time,key=i%60,首先当前key的数量减1。
* 如果key=0,则求剩余的数中key=0的数量。
* 如果key>0,则求60-key的数量。
 

代码:

public class Solution1010 {public int numPairsDivisibleBy60(int[] time) {int[] map = new int[60];for (int i : time) {map[i % 60]++;}int result = 0;for (int i : time) {int key = i % 60;map[key]--;if (key > 0) {result += map[60 - key];} else {result += map[key];}}return result;}
}

http://www.lryc.cn/news/66464.html

相关文章:

  • 利用老毛桃pe启动U盘启动ubuntu.iso,完成ubuntu系统的安装
  • 分享2个教学视频录制的方法!
  • 「SQL面试题库」 No_63 报告的记录 II
  • 【事务】怎么去理解事务?
  • camunda流程变量如何使用
  • CMIP6:WRF模式动力降尺度、单点降尺度、统计方法区域降尺度
  • 2023建筑设计师们有哪些好用的AI设计工具?
  • mysql主从复制与读写分离
  • 技术控,看这里,一款支持断点调试的数据科学工具
  • 论文导读 | 大语言模型上的精调策略
  • 进阶自动化测试,这3点你一定要知道的...
  • 网络编程套接字API
  • 数字藏品的价值和意义
  • Unity物理系统脚本编程(上)
  • Java基础(十七)File类与IO流
  • 跑步课程导入能力,助力科学训练
  • MySQL---8、创建和管理表
  • 图像分类简单介绍
  • 很多博主用Markdown格式文章?直呼真不错!
  • 【2023/05/07】汇编语言
  • AI 生成第3篇测试文章:怎么编写测试计划?
  • 怎么洗稿容易过稿-在线洗稿软件
  • 图书馆客流人数统计分析系统方案
  • linux命令之crontab详解
  • 浅谈一下接口工具(jmeter、postman、swagger等)
  • 面试题:react、 vue中的key有什么作用? (key的内部原理)
  • C++之继承
  • 轻松掌握!Pandas的数据添加技巧,3秒学会更高效的方法
  • 层次结构工程命名建议
  • Google Play应用广告该如何运作