将数组分成和相等的三个部分(Java版)

输入:[3,3,6,5,-2,2,5,1,-9,4]
输出:true
解释:3 + 3 = 6 = 5 - 2 + 2 + 5 + 1 - 9 + 4

最开始的时候尝试将数组分成三部分分别求其和,但发现在某些测试例中会陷入死循环。

将数组分成和相等的N个部分也可参照该方法进行改进

public boolean canThreePartsEqualSum(int[] A) {

        if(A.length<3||A==null) return false;
        //其思想为先找第一部分其值为sum/3
        //然后找第三部分其值为sum/3
        //如果找到切h-l>0则返回true

        //时间复杂度为O(n)
        int sum=0;
        int length=A.length;
        for (int i = 0; i < length; i++)  sum+=A[i];
        if(sum%3!=0) return false;    //如果数组之和取模3非0则无法分成三等份
        int lr=0;        //第一部分结果
        int hr=0;        //第三部分结果
        int l=0;         //第一部分结尾下标
        int h=length-1;  //第三部分开始下标,初始值随意,但必须h-l>0
        boolean lo=false; //第一部分是否查找结束
        boolean ho=false; //第三部分是否查找结束
        int r=sum/3;     //目标值
        for (int i = 0; i < length&&h>l+1; i++) {
            if(!lo){
                l=i;
                if((lr+=A[l])==r){
                    lo=true;
                }
            }
            if(!ho){
                h=length-1-i;
                if((hr+=A[h])==r){
                    ho=true;
                }
            }
            if(lo&&ho){
                return true;//达到目标,返回true
            }
        }
        return false;   
    }

  • 1
    点赞
  • 0
    收藏
  • 打赏
    打赏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

心怀啊

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

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值