数组包含正数负数和0,要求从中找出3个数的乘积,使得乘积最大

给定一个无序数组,包含正数、负数和0,要求从中找出3个数的乘积,使得乘积最大,要求时间复杂度:O(n),空间复杂度:O(1)

我就笑了,逻辑不难,但你搞个基本数据类型存不下的值,这就很坑了,兄弟。

import java.math.BigInteger;
import java.util.Arrays;
import java.util.Scanner;
import java.math.*;
//所有注释都是测试不对的
//可以参考。。。。懒得看请忽略
public class Main{
public static void main(String []args){
Scanner sc= new Scanner(System.in);
int dat=sc.nextInt();
int[] arr=new int[dat];
for(int i=0;i<dat;i++){
arr[i]=sc.nextInt();
}

for(int i=0;i<dat;i++){
for(int j=1;j<dat;j++){
if(arr[j-1]>arr[j]){
int tem=arr[j];
arr[j]=arr[j-1];
arr[j-1]=tem;
}
}}
// System.out.println(Arrays.toString(arr));
//     long b1=807120253114l;
//    long bm=807120253114;//这么写默认int类型,报错,超出范围
//     System.out.println(b1);
//     long m2=9223372036854775807l;
//    StringBuilder m1=new StringBuilder("");
//
BigInteger a,b;//记录两个值
int com;//比较时用的标记
BigInteger bl0 = new BigInteger(arr[0]+"");
BigInteger bl1 = new BigInteger(""+arr[1]);
BigInteger br1 = new BigInteger(""+arr[dat-1]);
BigInteger br2 = new BigInteger(""+arr[dat-2]);
BigInteger br3 = new BigInteger(""+arr[dat-3]);


a=br1.multiply(br2).multiply(br3);
b=bl0.multiply(bl1).multiply(br1);
com= a.compareTo(b);
if(com==1){
System.out.println(a);
}else {
System.out.println(b);

}
//     a=arr[0]*arr[1]*arr[dat-1];
//     BigInteger temp = new BigInteger(a);
//
//     System.out.println(a+"cao");
//     b=arr[dat-1]*arr[dat-2]*arr[dat-3]+0l;
//    if(a>b){
//        m1.append(a);
//    }else{m1.append(b);}
//System.out.print(a);
}

}
#笔试题目#
全部评论

相关推荐

不愿透露姓名的神秘牛友
06-19 19:05
点赞 评论 收藏
分享
04-25 18:13
五邑大学 Java
后来123321:大二两段实习太厉害了,我现在大二连面试都没有
点赞 评论 收藏
分享
董春花_:真诚无罪,别听评论区那个清华的。按他的逻辑,你有分寸人觉得你是不想来,你积极热情人觉得你太想来,你好骗人就可你养鱼,你不好骗人觉得你服从性不高,合着**做啥都白扯。保持谦逊礼貌与对offer的积极性不才是最正常,也正确的做法么?招聘方的错强加到应聘者身上,***何不食肉糜。
点赞 评论 收藏
分享
评论
点赞
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务