最大最小公倍数(贪心)
问题描述
已知一个正整数N,问从1~N中任选出三个数,他们的最小公倍数最大可以为多少。
输入格式
输入一个正整数N。
输出格式
输出一个整数,表示你找到的最小公倍数。
样例输入
9
样例输出
504
数据规模与约定
1 <= N <= 106。
规则;
#如果n是奇数,那么 n、n-1、n-2必定两两互质,要是有些纠结的话,那么我们就分析在什么情况下可能会存在公因子。n是奇数,那么n,n-1,n-2一定是两奇加一偶的情况。公因子2直接pass,因为只有一个偶数。假设剩下的n,n-2中有一个数能被3整除,那么有公因子的数一定是n或n-2加减3才能得到的情况。为此,n,n-1,n-2的乘积不仅是最大的,而且一定两两互质。
#如果n是偶数,继续分析n*(n-1)(n-2),这样的话n和n-2必定有公因子2,若偶数本身就能被3整除的话,那么式子n(n-1)(n-3)也不成立了,就变成了(n-1)(n-2)*(n-3),
n=int(input())
if n<3:
ans=0
if n%2==1:
ans=(n-1)*(n-2)*n
else:
if n%3:
ans=n*(n-1)*(n-3)
else:
ans=(n-3)*(n-1)*(n-2)
print(ans)