全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

如何用纯 Python 实现“将列表中每个位置替换为其余元素乘积”的函数

该教程讲解如何编写一个纯 python 函数,对输入列表的每个索引 i,生成新列表,其中第 i 个元素为原列表中除 arr[i] 外所有元素的乘积,其余位置保持原值。

在算法题和实际工程中,常遇到一类经典变换:给定一个整数列表 arr,要求构造一个新列表 result,使得 result[i] 等于 arr 中除 arr[i] 以外所有元素的乘积。注意:这不是返回单个结果,而是为每个位置生成一个“局部替换”后的完整列表——即共生成 n 个长度为 n 的列表(n = len(arr)),第 i 个列表是将原列表第 i 个位置替换为其余元素乘积所得。

例如,对 arr = [69, 78, 62, 73, 23]:

  • 第 0 个输出:[8119644, 78, 62, 73, 23] → 78×62×73×23 = 8119644
  • 第 1 个输出:[69, 7182762, 62, 73, 23] → 69×62×73×23 = 7182762
  • …以此类推。

✅ 正确思路与常见误区

你原始代码的问题在于:

results = arr  # ❌ 错误:这是浅拷贝,修改 results 就等于修改原 arr!

这导致每次循环都在污染同一个列表对象,后续迭代基于已被篡改的数据计算,结果完全错误。此外,使用 np.prod() 违反了“不依赖 NumPy”的要求。

✅ 纯 Python 实现(无 NumPy,安全高效)

以下是推荐的清晰、健壮实现:

def multiList(arr):
    """
    对输入列表 arr,返回一个包含 len(arr) 个列表的列表。
    其中第 i 个子列表是:将 arr[i] 替换为 arr 中其余所有元素乘积的结果。
    注意:不修改原列表,支持含零、负数、重复元素。
    """
    if not arr:
        return []

    n = len(arr)
    # 预先计算总乘积(需谨慎处理零)
    total_prod = 1
    zero_count = 0
    for x in arr:
        if x == 0:
            zero_count += 1
        else:
            total_prod *= x

    result = []
    for i in range(n):
        if zero_count > 1:
            # 两个及以上零 → 无论替换哪个位置,其余元素乘积必为 0
            new_list = arr.copy()
            new_list[i] = 0
            result.append(new_list)
        elif zero_count == 1:
            # 恰好一个零:仅当 i 指向该零时,其余乘积 = total_prod;否则为 0
            if arr[i] == 0:
                new_list = arr.copy()
                new_list[i] = total_prod
                result.append(new_list)
            else:
                new_list = arr.copy()
                new_list[i] = 0
                result.append(new_list)
        else:
            # 无零:直接 total_prod // arr[i]
            new_list = arr.copy()
            new_list[i] = total_prod // arr[i]  # 整数安全(假设输入为整数)
            result.append(new_list)

    return result

# ✅ 测试示例
arr = [69, 78, 62, 73, 23]
output = multiList(arr)
for i, lst in enumerate(output):
    print(f"Index {i}: {lst}")

输出:

Index 0: [8119644, 78, 62, 73, 23]
Index 1: [69, 7182762, 62, 73, 23]
Index 2: [69, 78, 9036378, 73, 23]
Index 3: [69, 78, 62, 7674732, 23]
Index 4: [69, 78, 62, 73, 24358932]

⚠️ 关键注意事项

  • 深拷贝 vs 浅拷贝:务必使用 arr.copy()(或 list(arr))创建新列表,避免原地修改。
  • 零值处理:若列表含零,直接用 total_prod / arr[i] 会触发除零错误或逻辑错误。上述实现已完备处理 0、1、≥2 个零的全部情况。
  • 整数除法:若输入全为整数,// 更安全;若含浮点数,改用 / 并确保类型一致。
  • 时间复杂度:O(n),仅两次遍历,高效无嵌套循环。
  • 空间复杂度:O(n²),因需存储 n 个长度 n 的列表——这是题目语义决定的,无法避免。

✅ 总结

该函数的核心是:分离“总乘积计算”与“逐位替换”逻辑,并严格隔离每个输出列表的内存空间。避开浅拷贝陷阱、鲁棒处理边界值(尤其是零),即可得到准确、可复用的解决方案。无需外部库,纯 Python 即可优雅实现。


# python  # app  # elif 


相关文章: 小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?  C++用Dijkstra(迪杰斯特拉)算法求最短路径  音响网站制作视频教程,隆霸音响官方网站?  南平网站制作公司,2025年南平市事业单位报名时间?  青浦网站制作公司有哪些,苹果官网发货地是哪里?  学校免费自助建站系统:智能生成+拖拽设计+多端适配  已有域名如何免费搭建网站?  如何选择最佳自助建站系统?快速指南解析优劣  建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略  如何在IIS中新建站点并解决端口绑定冲突?  c++ stringstream用法详解_c++字符串与数字转换利器  免费制作小说封面的网站有哪些,怎么接网站批量的封面单?  宝塔建站无法访问?如何排查配置与端口问题?  网站制作员失业,怎样查看自己网站的注册者?  北京制作网站的公司,北京铁路集团官方网站?  如何配置WinSCP新建站点的密钥验证步骤?  如何快速查询网址的建站时间与历史轨迹?  如何快速搭建高效WAP手机网站?  济南专业网站制作公司,济南信息工程学校怎么样?  临沂网站制作公司有哪些,临沂第四中学官网?  c# Task.ConfigureAwait(true) 在什么场景下是必须的  如何在阿里云通过域名搭建网站?  如何选择美橙互联多站合一建站方案?  建站之星代理费用多少?最新价格详情介绍  建站之星如何实现PC+手机+微信网站五合一建站?  常州企业网站制作公司,全国继续教育网怎么登录?  如何通过虚拟主机快速搭建个人网站?  ,怎么在广州志愿者网站注册?  如何在VPS电脑上快速搭建网站?  网站企业制作流程,用什么语言做企业网站比较好?  Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解  如何通过主机屋免费建站教程十分钟搭建网站?  建站主机选哪种环境更利于SEO优化?  建站之星与建站宝盒如何选择最佳方案?  建站主机数据库如何配置才能提升网站性能?  如何在阿里云高效完成企业建站全流程?  完全自定义免费建站平台:主题模板在线生成一站式服务  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  如何在企业微信快速生成手机电脑官网?  JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)  如何通过商城自助建站源码实现零基础高效建站?  专业网站建设制作报价,网页设计制作要考什么证?  如何制作一个表白网站视频,关于勇敢表白的小标题?  天津个人网站制作公司,天津网约车驾驶员从业资格证官网?  如何在宝塔面板中修改默认建站目录?  建站之星代理如何优化在线客服效率?  如何在Windows虚拟主机上快速搭建网站?  如何使用Golang table-driven基准测试_多组数据测量函数效率  如何访问已购建站主机并解决登录问题? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。