蓝桥杯 算法训练最大最小公倍数 Java

问题描述

已知一个正整数N,问从1~N中任选出三个数,他们的最小公倍数最大可以为多少。


输入格式

输入一个正整数N。


输出格式

输出一个整数,表示你找到的最小公倍数。


样例输入

9


样例输出

504


数据规模与约定

1 <= N <= 106。


先判断N的奇偶,若为奇数,选最大的三位数,N,N-1,N-2;

若为偶数,N,N-2必有公约数2,则N,N-1,N-2最小公倍数不是三数相乘也不为最大,为偶数时,又可分为N是否能被3整除,当输入N=8时,为偶数,考虑选择8,7,5,当输入N=6时,6,5,3,其中6,3存在公约数,N=12,同理,则N=6时,选择5,4,3为最优解。

由上可得,奇:N*N-1*N-2;

                  偶:N%3!=0: N*N-1*N-3

                         N%3==0:N-1*N-2*N-3

:输出结果是3位数相乘的结果,会非常大,所有要用长整型,在java中,输入N为int型,在三个int型相乘时结果仍未int型,即使ans定义为long型,结果并不会自动转为long,需要在计算时进行强制类型转换。

import java.util.*;
public class Main {
    public static void main(String[] args){
        Scanner input = new Scanner(System.in);
       int N = input.nextInt();
       long ans=0;
       if(N%2==0){
           if(N%3==0){
               ans=(long)(N-1)*(N-2)*(N-3);
           }else{
               ans=(long)N*(N-1)*(N-3);
           }
       }else{
           ans=(long)N*(N-1)*(N-2);
       }
       System.out.println(ans);
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值