ACM------First Blood(合工大OJ 1343)


 

int main(){
    int T;
    scanf("%d",&T);
    while(T--){
        long long n,max;
        scanf("%I64d",&n);
        if(n<=2)max=n;
        else if(n%2==1)  max=n*(n-1)*(n-2);              //奇数                           
             else if(n%3==0)max=(n-1)*(n-2)*(n-3);        //偶数
                  else max=n*(n-1)*(n-3);
        printf("%I64d\n",max);        
    }
}

 

这是我参加ACM练习做的第一道题,最大的感受就是刚入门格式太繁琐了,以前无论写什么程序,直接用int,float,随便举几个数进行测试,基本都ok,但现在明显感觉到解决问题没有那么简单。

 

题目要求输入的数据小于10^6,一开始认为int肯定够用,但稍微思考下,就会发现,3个10^6的数相乘,已经达到了18次方的级别,这时候只能使用long long。下一篇文章是我从网上转载的关于acm中,几种整型的表现形式。

__int64与long long、long的区别

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

靓仔很忙i

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

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

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

打赏作者

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

抵扣说明:

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

余额充值