力扣3185.构成整天的下标对数

给你一个整数数组 hours,表示以 小时 为单位的时间,返回一个整数,表示满足 i < jhours[i] + hours[j] 构成 整天 的下标对 i, j 的数目。

整天 定义为时间持续时间是 24 小时的 整数倍

例如,1 天是 24 小时,2 天是 48 小时,3 天是 72 小时,以此类推。

示例 1:

输入: hours = [12,12,30,24,24]

输出: 2

解释:

构成整天的下标对分别是 (0, 1)(3, 4)

示例 2:

输入: hours = [72,48,24,3]

输出: 3

解释:

构成整天的下标对分别是 (0, 1)(0, 2)(1, 2)

复制代码
class Solution:
    def countCompleteDayPairs(self, hours: List[int]) -> int:
        k = 0    # 计数符合条件的对数
        n = len(hours)
        # 双重循环检查每对组合
        for i in range(n):
           for j in range(i):
                if (hours[i]+hours[j]%24 == 0):   # 判断是否为24的倍数
                      k++
        return k

优化

思路:

  1. 两数之和是24的倍数问题 可以转化为一个余数相配问题。
  2. 我们可以通过哈希表(计数数组)来记录每个小时数除以24的余数出现的次数。
  3. 如果两个小时数的余数之和为24(或是0,如[0, 0]),那么它们可以配对。

优化算法:

  • 维护一个大小为24的数组 remainder_count,用来记录每个余数出现的次数。
  • 遍历 hours,对于每个小时数计算其余数,然后根据当前的已知配对策略进行统计。

举例

借鉴 1. 两数之和 的思路,遍历 hours 的同时,用一个哈希表(或者数组)记录元素的出现次数。

举几个例子:

如果 hours[i]=1,那么需要知道左边有多少个模 24 是 23 的数,这些数加上 1 都是 24 的倍数。

如果 hours[i]=2,那么需要知道左边有多少个模 24 是 22 的数,这些数加上 2 都是 24 的倍数。

如果 hours[i]=26,那么需要知道左边有多少个模 24 是 22 的数,这些数加上 26 都是 24 的倍数。

一般地,对于 hours[i],需要知道左边有多少个模 24 是 24−hours[i]mod24 的数。

特别地,如果 hours[i] 模 24 是 0,那么需要知道左边有多少个模 24 也是 0 的数。

这两种情况可以合并为:累加左边(24−hours[i]mod24)mod24的出现次数。

代码实现时,用一个长为 24 的数组 cnt 维护 hours[i]mod24 的出现次数。

python 复制代码
from typing import List

class Solution:
    def countCompleteDayPairs(self, hours: List[int]) -> int:
        remainder_count = [0] * 24  # 记录每个余数的出现次数
        pairs = 0  # 记录有效配对的数量

        # 遍历每个小时数
        for hour in hours:
            remainder = hour % 24  # 计算余数
            complement = (24 - remainder) % 24  # 找到配对所需的余数
            
            # 如果已经有配对的余数,增加配对数量
            pairs += remainder_count[complement]
            
            # 更新当前余数的计数
            remainder_count[remainder] += 1
        
        return pairs

参考:灵茶山艾府--https://leetcode.cn/problems/count-pairs-that-form-a-complete-day-ii/solutions/2812385/tao-lu-mei-ju-you-wei-hu-zuo-pythonjavac-3vhv/

相关推荐
惊鸿.Jh18 分钟前
【滑动窗口】3254. 长度为 K 的子数组的能量值 I
数据结构·算法·leetcode
明灯L19 分钟前
《函数基础与内存机制深度剖析:从 return 语句到各类经典编程题详解》
经验分享·python·算法·链表·经典例题
碳基学AI25 分钟前
哈尔滨工业大学DeepSeek公开课:探索大模型原理、技术与应用从GPT到DeepSeek|附视频与讲义免费下载方法
大数据·人工智能·python·gpt·算法·语言模型·集成学习
补三补四28 分钟前
机器学习-聚类分析算法
人工智能·深度学习·算法·机器学习
独好紫罗兰38 分钟前
洛谷题单3-P5718 【深基4.例2】找最小值-python-流程图重构
开发语言·python·算法
正脉科工 CAE仿真1 小时前
基于ANSYS 概率设计和APDL编程的结构可靠性设计分析
人工智能·python·算法
Dovis(誓平步青云)1 小时前
【数据结构】排序算法(中篇)·处理大数据的精妙
c语言·数据结构·算法·排序算法·学习方法
2401_872945091 小时前
【补题】Xi‘an Invitational 2023 E. Merge the Rectangles
算法
暮雨哀尘2 小时前
微信小程序开发:开发实践
开发语言·算法·微信小程序·小程序·notepad++·性能·技术选型
Touper.2 小时前
L2-003 月饼
数据结构·算法·排序算法