python笔试题-平衡点问题: 假如一个数组中的元素,其前面的部分等于后面的部分,那么这个点的位序就是平衡点。

平衡点问题

假如一个数组中的元素,其前面的部分等于后面的部分,那么这个点的位序就是平衡点。
比如一个列表numbers = [1, 3, 5, 7, 8, 25, 4, 20]。25前面的总和为24,25,后面的总和也是24,那么这个点就是平衡点。
要求编写程序,寻找并返回任意一个列表的平衡点。

def balance_point(thy_list):
    num = len(thy_list)
    if num >= 3:
        for i in range(num):
            if i == 0:
                pass
            else:
                list1 = thy_list[:i]  # 将传入的列表切片,将一个列表分成2个列表
                list2 = thy_list[i+1:]
                sum1 = sum(list1)   # 对切片后的列表分别求和
                sum2 = sum(list2)
                if sum1 == sum2:
                    return '平衡点:%d,其值为%d' % (i, thy_list[i])
        return '无平衡点'
    else:
        return '列表长度不够!'


if __name__ == '__main__':
    print(balance_point([1, 3, 5, 7, 8, 25, 4, 20]))
    print(balance_point([1, 3, 5, 7, 8, 25, 4, 26]))
    print(balance_point([1, 3, 5, 7, 8, 7, 5, 4]))
    print(balance_point([1]))
    print(balance_point([100, 200, 100]))
# 结果:

# 平衡点:5,其值为25
# 无平衡点
# 平衡点:4,其值为8
# 列表长度不够!
# 平衡点:1,其值为200
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值