最⼤最⼩公倍数(贪⼼算法)

问题描述
已知⼀个正整数N,问从1~N中任选出三个数,他们的最⼩公倍数最⼤可以为多少。
输⼊格式
输⼊⼀个正整数N。
输出格式
输出⼀个整数,表示你找到的最⼩公倍数。
样例输⼊
  9
样例输出
  504
数据规模与约定
  1 <= N <= 10^6。
分析:
  1.如果 n <= 2, 那么最⼩公倍数为 n
  2.如果 n 是奇数,那么最⼩公倍数的最⼤值为末尾的三个数相乘
  3.如果是偶数的话,如果同时出现两个偶数肯定会不能构成最⼤值了,因为会被除以2~~分两种情
况:
  (1)如果 n 是偶数且不是三的倍数, ⽐如8,那么跳过n-2这个数⽽选择 8 7 5 能保证不会最⼩公倍数
被除以2~~所以最⼩公倍数的最⼤值为n * (n – 1) * (n – 3)
  (2)如果 n 是偶数且为三的倍数,⽐如6,如果还像上⾯那样选择的话,6和3相差3会被约去⼀个3,⼜
不能构成最⼤值了。那么最⼩公倍数的最⼤值为(n – 1) * (n – 2) * (n – 3)

#include <iostream>  
using namespace std;  
int main() {  
    long long n, ans;  
    cin >> n;  
    if(n <= 2)  
        ans = n;  
    else if(n % 2 == 1)  
        ans = n * (n-1) * (n-2);  
    else if(n % 3 == 0)  
        ans = (n - 1) * (n - 2) * (n - 3);  
    else  
        ans = n * (n - 1) * (n - 3);    
    cout << ans;  
    return 0;  
}

原文链接:https://www.liuchuo.net/archives/tag/%E8%B4%AA%E5%BF%83%E7%AE%97%E6%B3%95

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值