该教程讲解如何编写一个纯 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]:
你原始代码的问题在于:
results = arr # ❌ 错误:这是浅拷贝,修改 results 就等于修改原 arr!
这导致每次循环都在污染同一个列表对象,后续迭代基于已被篡改的数据计算,结果完全错误。此外,使用 np.prod() 违反了“不依赖 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]
该函数的核心是:分离“总乘积计算”与“逐位替换”逻辑,并严格隔离每个输出列表的内存空间。避开浅拷贝陷阱、鲁棒处理边界值(尤其是零),即可得到准确、可复用的解决方案。无需外部库,纯 Python 即可优雅实现。
相关文章:
小米网站链接制作教程,请问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小时内与您取得联系。