0

0

计算嵌套列表中跨子列表的重复元素之和

霞舞

霞舞

发布时间:2025-09-29 17:47:02

|

198人浏览过

|

来源于php中文网

原创

计算嵌套列表中跨子列表的重复元素之和

本文旨在提供一种高效且准确的方法,用于计算嵌套列表中跨多个子列表出现的重复元素之和。传统方法可能涉及扁平化列表和统计元素出现次数,但这种方法效率较低。本文介绍一种利用字典和集合的优化方案,能够更有效地处理嵌套列表中的重复元素,并提供相应的Python代码示例和详细解释。

问题描述

给定一个嵌套列表,其中包含多个子列表,我们需要计算所有在至少两个子列表中出现的元素的总和。例如,对于输入 [[1, 2, 3], [2, 8, 9], [7, 123, 8]],数字2和8分别出现在多个子列表中,因此结果应为 2 + 8 = 10。如果某个数字仅出现在一个子列表中,则不应将其计入总和。

解决方案:使用字典和集合

为了更有效地解决这个问题,我们可以利用字典来记录每个数字出现的子列表数量,并使用集合来避免重复计数。具体步骤如下:

  1. 初始化字典: 创建一个空字典 seen,用于存储每个数字及其出现的子列表数量。
  2. 遍历子列表: 遍历嵌套列表中的每个子列表。
  3. 遍历子列表中的元素: 遍历当前子列表中的每个元素。为了避免在同一个子列表中重复计数某个元素,我们首先将子列表转换为集合 {*subl}。
  4. 更新字典: 对于每个元素,更新 seen 字典中对应的值。如果元素已存在,则将其值加1;否则,将其添加到字典中,并将其值设置为1。
  5. 计算总和: 遍历 seen 字典,将所有值大于1的键(即在多个子列表中出现的数字)加起来,得到最终结果。

Python 代码示例

def repeat_sum(arr):
    seen = {}
    for subl in arr:
        for v in {*subl}:
            seen[v] = seen.get(v, 0) + 1
    return sum(k for k, v in seen.items() if v > 1)

# 示例用法
test_cases = [
    [[1, 2, 3], [2, 8, 9], [7, 123, 8]],
    [[1, 8, 8], [8, 8, 8], [8, 8, 8, 1]],
    [[1], [2], [3, 4, 4, 4], [123456789]],
]

for t in test_cases:
    print(t, repeat_sum(t))

代码解释:

MyMap AI
MyMap AI

使用AI将想法转化为图表

下载
  • seen = {}: 初始化一个空字典,用于存储每个数字出现的次数。
  • for subl in arr:: 遍历输入的嵌套列表 arr 中的每个子列表 subl。
  • for v in {*subl}:: 将子列表 subl 转换为集合 {*subl},然后遍历集合中的每个元素 v。 使用集合可以确保同一个子列表中的重复元素只被计数一次。
  • seen[v] = seen.get(v, 0) + 1: 更新字典 seen 中元素 v 的计数。 seen.get(v, 0) 获取 v 在字典中对应的值,如果 v 不存在,则返回默认值 0。 然后将值加 1,并更新字典。
  • return sum(k for k, v in seen.items() if v > 1): 遍历字典 seen 中的每个键值对 (k, v),其中 k 是数字,v 是数字出现的次数。 如果 v 大于 1,则说明数字 k 在多个子列表中出现过,将其加入总和。

示例输出

[[1, 2, 3], [2, 8, 9], [7, 123, 8]] 10
[[1, 8, 8], [8, 8, 8], [8, 8, 8, 1]] 9
[[1], [2], [3, 4, 4, 4], [123456789]] 0

总结

通过使用字典和集合,我们可以高效地计算嵌套列表中跨子列表的重复元素之和。这种方法避免了扁平化列表和重复计数,提高了代码的效率和可读性。在处理类似问题时,可以借鉴这种思路,利用合适的数据结构来优化算法。

注意事项:

  • 此方法适用于数字类型的元素。如果列表中包含其他类型的元素,需要进行相应的类型转换或修改代码。
  • 如果需要考虑元素出现的顺序,则不能使用集合,而需要使用其他方法来避免重复计数。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

783

2023.08.22

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

539

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

21

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

31

2026.01.06

C++类型转换方式
C++类型转换方式

本专题整合了C++类型转换相关内容,想了解更多相关内容,请阅读专题下面的文章。

301

2025.07.15

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

419

2023.08.14

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

2

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

1

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 3.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号