蓝桥杯 算法训练 最大分解(Python)

资源限制

内存限制:256.0MB   C/C++时间限制:1.0s   Java时间限制:3.0s   Python时间限制:5.0s

问题描述

  给出一个正整数n,求一个和最大的序列a0,a1,a2,……,ap,满足n=a0>a1>a2>……>ap且ai+1是ai的约数,输出a1+a2+……+ap的最大值

输入格式

  输入仅一行,包含一个正整数n

输出格式

  一个正整数,表示最大的序列和,即a1+a2+……+ap的最大值

样例输入

10

样例输出

6

数据规模和约定

  1<n<=10^6

样例说明

  p=2
  a0=10,a1=5,a2=1,6=5+1

# 这道题我的第一思路是DFS深度优先遍历将每一种因数遍历一遍,最后保留最大值
n = int(input())
maxs = 1
sums = 0


def dfs(num):
    global sums, maxs
    if num == 2 or num == 3:  # 如果是2或3直接可以得出结果1,或者最后分解到2或3,加1即可
        sums += 1
        maxs = max(maxs, sums)  # 每次得到最后结果后保留较大值
        sums -= 1  # 计算结束后要减去1,以免影响向上返回计算其他路径的值
        return
    temp = 0  # 标记得到的两个因数中较大的,也可以判断是否是素数
    for i in range(2, int(num / 2) + 1):
        if num % i == 0:
            temp = int(num / i)
            if temp == i:  # 如果得到的两个因数相同则直接加上后再加1
                sums += (temp + 1)
                maxs = max(maxs, sums)
                sums -= (temp + 1)
                return
            # 正常情况就从大到小依次分解,此处是较大的因数
            sums += temp
            dfs(temp)
            sums -= temp
            # 另一个较小的因数
            sums += i
            dfs(i)
            sums -= i
    if temp == 0:  # 此处temp如果为0,则说明没有分解出因数,该数是素数,则加1即可
        sums += 1
        maxs = max(maxs, sums)
        sums -= 1
        return


dfs(n)
print(maxs)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

&&CQ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值