UVA 10791——Minimum Sum LCM (算数基本定理)

    题目链接

    题目大意 : 给你一个数n,让你将这个数分解成至少两个数,对每一个分解式进行求和,算出其中最小的那一个。

    为什么按照算数基本定理算出来的数字就是最小的呐疑问:因为每一个数字都可以运用算数基本定理进行分解,如果所用的因数不是所分解的这些质数,那么那样求出来的和一定比这样分解的数大,因为那些不为素数的数字还可以再继续分。

     算数基本定理: 任何一个大于1的自然数 N,那么N可以唯一分解成有限个质数的乘积N=P1a1P2a2P3a3......Pnan,这里P1<P2<P3......<Pn均为质数,其中指数ai是正整数。这样的分解称为N 的标准分解式

Code:

#include<bits/stdc++.h>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
using namespace std;
typedef long long LL;

int main()
{
    LL n;
    int kase = 0;
    while(scanf("%lld", &n) && n != 0)
    {
        LL a, flag = 0, ans = 0;
        LL x = (long long)sqrt(n) + 10;
        for(LL i = 2; i <= sqrt(n); i++)
        {
            a = 0;
            LL temp = 0;
            if(n %i == 0)
            {
                flag++;
                temp = 1;
                while(n%i == 0)
                {
                    temp *= i;
                    n /= i;
                }
            }
            ans += temp;
        }
        if(flag == 0)
            ans = n+1;
        else if(flag == 1 || n != 1)
            ans += n;
        printf("Case %d: %lld\n",++kase, ans);
    }
    return 0;
}

好好加油!!!



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值