鱼C论坛

 找回密码
 立即注册
查看: 1464|回复: 5

[已解决]不超过5层的嵌套列表求列表元素加权和

[复制链接]
发表于 2022-3-5 00:49:26 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
【问题描述】

输入一个嵌套列表,嵌套层次不超过5层,根据层次,求列表元素的加权和,权是指元素在嵌套列表中的层次。第一层每个元素的权值为:元素值*1,第二层每个元素的权值为:元素值*2,第三层每个元素的权值为:元素值*3, ...,依此类推!


【输入形式】

按照列表的形式输入,每个元素是一个整数
【输出形式】

整数
【样例输入】

[1,2,[3,4,[5,6],7],8]

【样例输出】

72

【样例说明】

元素1,2,8是列表的第一层,所以其权是1。3,4,7 处于列表的第二层,其权是2。5,6处于列表的第三层,其权是3。所以列表元素的加权和为:

(1+2+8)*1+(3+4+7)*2+(5+6)*3=72
最佳答案
2022-3-5 09:14:19
def func(arr, level = 1):
        res = 0
        for each in arr:
                if type(each) == int:
                        res += each*level
                else:
                        res += func(each, level + 1)
        return res

arr = [1, 2, [3, 4, [5, 6], 7], 8]

print(func(arr))
72
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-3-5 02:38:19 | 显示全部楼层
递归就可以解决
def f_ist(nl,j):
    global b
    j =j+1
    for i in nl:
        if type(i) is int:
            b = b + i*j
            #print(i,j,b)#去掉注释可以看见计算过程
        elif type(i) is list:
            f_ist(i,j)
    return(b)

a =[1, 2, [3, 4, [5, 6], 7], 8]
b = 0
print(f_ist(a,0))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-5 02:39:59 | 显示全部楼层
elven08 发表于 2022-3-5 02:38
递归就可以解决

这个是计算过程和结果。
1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-5 09:14:19 From FishC Mobile | 显示全部楼层    本楼为最佳答案   
def func(arr, level = 1):
        res = 0
        for each in arr:
                if type(each) == int:
                        res += each*level
                else:
                        res += func(each, level + 1)
        return res

arr = [1, 2, [3, 4, [5, 6], 7], 8]

print(func(arr))
72

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
isdkz + 5 + 5 鱼C有你更精彩^_^

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 2 反对 0

使用道具 举报

 楼主| 发表于 2022-3-5 12:25:05 | 显示全部楼层
elven08 发表于 2022-3-5 02:38
递归就可以解决

谢谢大佬
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-3-5 12:25:37 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-12 06:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表