全网整合营销服务商

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

免费咨询热线: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 


相关文章: 宝华建站服务条款解析:五站合一功能与SEO优化设置指南  小程序网站制作需要准备什么资料,如何制作小程序?  如何快速启动建站代理加盟业务?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  如何通过多用户协作模板快速搭建高效企业网站?  定制建站策划方案_专业建站与网站建设方案一站式指南  大学网站设计制作软件有哪些,如何将网站制作成自己app?  SQL查询语句优化的实用方法总结  制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?  南平网站制作公司,2025年南平市事业单位报名时间?  建站之星在线版空间:自助建站+智能模板一键生成方案  建站之星如何通过成品分离优化网站效率?  建站主机默认首页配置指南:核心功能与访问路径优化  如何用VPS主机快速搭建个人网站?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  手机网站制作与建设方案,手机网站如何建设?  在线教育网站制作平台,山西立德教育官网?  seo网站制作优化,网站SEO优化步骤有哪些?  建站主机助手选型指南:2025年热门推荐与高效部署技巧  建站之星云端配置指南:模板选择与SEO优化一键生成  教学论文网站制作软件有哪些,写论文用什么软件 ?  如何通过FTP空间快速搭建安全高效网站?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  如何快速搭建支持数据库操作的智能建站平台?  自助网站制作软件,个人如何自助建网站?  建站三合一如何选?哪家性价比更高?  我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?  Python路径拼接规范_跨平台处理说明【指导】  成都网站制作公司哪家好,四川省职工服务网是做什么用?  如何在香港免费服务器上快速搭建网站?  贸易公司网站制作流程,出口贸易网站设计怎么做?  如何通过万网虚拟主机快速搭建网站?  制作企业网站建设方案,怎样建设一个公司网站?  如何用低价快速搭建高质量网站?  宝塔Windows建站如何避免显示默认IIS页面?  如何用AWS免费套餐快速搭建高效网站?  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?  定制建站如何定义?其核心优势是什么?  C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)  如何选择高效稳定的ISP建站解决方案?  如何通过老薛主机一键快速建站?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  简易网站制作视频教程,使用记事本编写一个简单的网页html文件?  如何在云指建站中生成FTP站点?  高防服务器租用如何选择配置与防御等级?  高防服务器租用首荐平台,企业级优惠套餐快速部署  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  济南企业网站制作公司,济南社保单位网上缴费步骤?  c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】 

您的项目需求

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