Leetcode 3267. Count Almost Equal Pairs II

  • Leetcode 3267. Count Almost Equal Pairs II
    • 1. 解题思路
    • 2. 代码实现
  • 题目链接:3267. Count Almost Equal Pairs II

1. 解题思路

这一题同样是题目3265. Count Almost Equal Pairs I的进阶版本。

它主要的区别在于说:

  1. 最大的操作次数增加到两次;
  2. 数组长度增加到最大5000

然后,首先对于操作次数的追加,我们要判断两个数是否是almost equal,就要满足如下几个要求:

  1. 所有出现的数字必须相同
  2. 位与位之间不同的位数最多不能超过4位
  3. 如果不同的位数恰好为4位,那么其必定是两个pair才行。

此时,我们就能完成almost equal的判断,剩下的就是如何对计算复杂度进行优化,这里的话我主要是进行了一下分组,由于两个数要满足almost equal那么他出现的所有位上的数必然是完全相同的,因此我们据此进行一下分组,然后只要对每一个组内的数字进行一下考察即可。

其次,在每一个组内,可能会有同一个数多次出现的case,我们也可以对这部分进行一个二次分组,这样也可以优化一些计算复杂度。

此时,我们得到的算法就可以通过全部的的测试样例了,虽然还是蛮暴力的,不过能work就行……

2. 代码实现

给出python代码实现如下:

class Solution:def countPairs(self, nums: List[int]) -> int:nums = [str(x).rjust(7, "0") for x in nums]cnt = defaultdict(lambda : defaultdict(int))for x in nums:sx = "".join(sorted(x))cnt[sx][x] += 1def is_almost_equal(x, y):diff = []for ch1, ch2 in zip(x, y):if ch1 != ch2:diff.append((ch1, ch2))if len(diff) <= 3:return Trueif len(diff) == 4:return (diff[0][1], diff[0][0]) in diffreturn Falseans = 0for group in cnt.values():items = list(group.items())n = len(items)for i in range(n):ans += items[i][1] * (items[i][1]-1) // 2for j in range(i+1, n):if is_almost_equal(items[i][0], items[j][0]):ans += items[i][1] * items[j][1]return ans

提交代码评测得到:耗时7247ms,占用内存17.7MB。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/52317.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# 循环访问目录树详解与示例

文章目录 一、目录树遍历的概念二、使用System.IO命名空间三、DirectoryInfo和FileInfo类四、递归遍历目录树五、示例&#xff1a;列出目录树中的所有文件和文件夹六、异常处理七、迭代方法八、总结 在C#中&#xff0c;访问文件系统是常见的需求之一。有时我们需要遍历目录树以…

kafak集群搭建-基于zookeeper方式

kafak集群搭建-基于zookeeper方式 1、准备3个kafka2、修改配置文件2.1、修改配置文件 3、启动测试3.1、先启动zookeeper3.2、再启动三台kafka 4、SpringBoot集成kafka集群4.1、项目配置文件application.yml4.2、kafka配置类4.3、启动SpringBoot程序 5、kafka集群架构分析6、查看…

学习能力与研究能力

摘要: 学习就像搭金字塔, 研究就像挖井. 1. 什么是学习 学习 (study) 是获得技能、知识、方法的过程. 学习有两种模式: 一是直接获得前人总结的经验; 二是从数据中总结规律. 2. 什么是研究 研究 (research) 是对已有或新的问题进行探索, 获得新技能、新知识、新方法的过程.…

【kubernetes】相关pod的创建和命令

【书写方法】&#xff1a; 管理使用k8s集群时&#xff0c;创建资源的Yaml文件非常重要&#xff0c;如何快速手写呢&#xff1f; 根据命令提示书写&#xff1a; kubectl explain [资源名称]例如打算写pod资源文件时&#xff0c;可查看如下&#xff1a; # 查看pod下所有字段 …

IO多路复用,select、poll和epoll简介

文章目录 前言1、select2、poll3、epoll4、总结 前言 select、poll 和 epoll 是 Linux 下用于多路复用 I/O&#xff08;Input/Output&#xff09;的系统调用&#xff0c;它们用于监视多个文件描述符&#xff0c;以查看哪个文件描述符上有可读、可写或发生了异常的事件。 1、sel…

python之多线程和多进程以及threading和multiprocessing模块

在 Python 中&#xff0c;多线程和多进程是实现并发编程的两种主要方式。多线程适用于 I/O 密集型任务&#xff0c;而多进程适用于 CPU 密集型任务。Python 提供了 threading 模块用于多线程编程&#xff0c;提供了 multiprocessing 模块用于多进程编程。 多线程 基本用法 使…

深度学习100问9-什么是word2vec模型

Word2vec 模型是一种用于将词语转换为向量表示的工具。 想象一下&#xff0c;我们有很多很多的词语&#xff0c;就像一个个不同的小盒子。Word2vec 模型的作用就是给每个小盒子都找到一个对应的位置&#xff0c;这个位置用一个向量来表示。这样&#xff0c;意思相近的词语在这…

Google Colab快速使用

Google Colab快速使用 1. 引言2. Jupyter笔记本的创建3. 上传代码和数据集4. Colab常规指令 1. 引言 Google Colab是谷歌提供的免费Jupyter&#xff0c;很类似于Linux系统这些在终端界面操纵的感觉&#xff0c;不需要深度学习环境配置就可以使用&#xff0c;完全基于云端运行。…

Shell输出、重定向与管道符

Shell输出、重定向与管道符 1、Shell输出1.1、标准输入输出1.2、echo指令1.3、print与printf指令 2、Shell重定向3、Shell管道符 由于Shell脚本批处理的特殊性&#xff0c;其大部分操作过程位于后台&#xff0c;不需要用户进行干预&#xff0c;因此&#xff0c;使用重定向和管道…

在Windows Server 2012 R2上安装.NET Framework 3.5

在Windows Server 2012 R2上安装.NET Framework 3.5&#xff0c;可以按照以下步骤进行&#xff1a; 打开服务器管理器&#xff1a; 首先&#xff0c;登录到Windows Server 2012 R2的服务器。然后&#xff0c;打开“服务器管理器”。添加角色和功能&#xff1a; 在“服务器管理…

react面试题五

一、请解释React中的高阶组件&#xff08;HOC&#xff09;和Hooks。 在React中&#xff0c;高阶组件&#xff08;High-Order Components, HOCs&#xff09;和Hooks是两种强大的特性&#xff0c;它们用于重用组件逻辑。尽管它们的目的相似&#xff0c;但它们在实现和使用方式上有…

使用Python恢复Windows、Linux、MacOS回收站中的文件和目录

一、使用Python恢复Windows回收站中的文件和目录 import os import platformdef put_back_trash():# 获取操作系统类型os_type platform.system()if os_type "Windows": # Windowsfrom winshell import recycle_binfor item in recycle_bin():winshell.undelete(…

针对防火墙IPSec业务不通或业务丢包问题,防火墙如何做流量统计、远程抓包、报文示踪

问题描述 针对防火墙IPSec业务不通或业务丢包问题&#xff0c;防火墙如何做流量统计、远程抓包、报文示踪 解决方案 1&#xff09;配置流统和远程抓包用的ACL&#xff1b; system [sysname] acl 3555 [sysname-acl-adv-3555] rule permit icmp source 10.82.100.215 0 destin…

结构型模式之代理模式

一、概述 1、代理模式&#xff1a;给某一个对象提供一个代理或占位符&#xff0c;并由代理对象来控制对原对象的访问。 2、代理对象在客户端和目标对象之间起到中介作用 3、引入一个新的代理对象&#xff0c;代理模式的主要目的是在不改变原始对象接口的前提下&#xff0c;增…

DORIS学习网址

DORIS学习网址 序号学习网址备注1ApacheDoris系列&#xff5c;Bucket(分桶)数量设置和自动分桶-CSDN博客自动分桶2Apache Doris 入门教程23&#xff1a;自动分桶和Broker概念介绍_doris broker-CSDN博客新版自动分桶说明3一文教你玩转 Apache Doris 分区分桶新功能&#xff5c;…

Spring 中AbstractRefreshableWebApplicationContext

AbstractRefreshableWebApplicationContext 是 Spring Framework 中用于 Web 应用程序的一个抽象类&#xff0c;位于 org.springframework.web.context.support 包中。它继承自 AbstractRefreshableApplicationContext&#xff0c;主要用于支持 Web 应用程序的上下文管理。 主…

[C语言]一、C语言基础(函数)

G:\Cpp\C语言精讲 6. 函数 6.1函数的基本使用 6.1.1 为什么需要函数 《街霸》游戏中&#xff0c;每次人物出拳、出脚或跳跃等动作都需要编写50-80行的代码&#xff0c;在每次出拳、出脚或跳跃的地方都需要重复地编写这50-80行代码&#xff0c;这样程序会变得很臃肿&#xff…

C++基础面试题 | C和C++的区别?

人生如逆旅&#xff0c;我亦是行人。 - 《临江仙送钱穆父》(苏轼) 2024.8.23 回答重点&#xff1a;C可以认为是C语言的超集&#xff0c;绝大部分C语言代码可以使用C运行 在设计思想上&#xff1a;面向过程 vs 面向对象 C是一种面向过程的编程语言&#xff0c;它侧重于函数和过程…

python学习8-数据获取与整理4

pandas迭代 在 Pandas 中&#xff0c;通常情况下你不需要迭代&#xff08;遍历&#xff09;DataFrame 或 Series&#xff0c;因为很多操作都是矢量化的&#xff0c;可以直接应用于整个数据集。然而&#xff0c;有时候你可能需要遍历数据帧&#xff08;DataFrame&#xff09;或…

通过Python绘制不同数据类型适合的可视化图表

在数据可视化中&#xff0c;对于描述数值变量与数值变量之间的关系常见的有散点图和热力图&#xff0c;以及描述数值变量与分类变量之间的关系常见的有条形图&#xff0c;饼图和折线图&#xff0c;可以通过使用Python的matplotlib和seaborn库来绘制图表进行可视化表达&#xff…