华为OD机试-MVP争夺战

题目描述

在星球争霸篮球赛对抗赛中,强大的宇宙战队,希望每个人都能拿到MVP。
MVP的条件是,单场最高分得分获得者,可以并列,所以宇宙战队决定在比赛中,尽可能让更多的队员上场,且让所有有得分的队员得分都相同。
然而比赛过程中的每一分钟的得分都只能由某一个人包揽。
输入描述: 输入第一行为一个数字t,表示有得分的分钟数( 1 <= t <= 50),第二行为t个数字,代表每一分钟的得分p(1 <= p <= 50)
输出描述: 输出有得分的队员都是MVP时最少的MVP得分。
补充说明:
示例
示例1
输入: 9
5 2 1 5 2 1 5 2 1
输出: 6
说明: 样例解释:一共4人得分,分别都为6分
5 + 1
5 + 1
5 + 1
2 + 2 + 2

代码

class Solution {
    public int getResult(int[] values) {
        int l = values.length;
        int sum=0;
        int max=-1;
        int[] temp=new int[l];
        for(int x:values){
            sum+=x;
            max=Math.max(max,x);
        }
        int groupMax=sum/max;//最多分的组数,再大一些mvp的得分比每日的最大分数还小,不可能。
        //遍历分组数。mvp得分一定是整数,如果是小数跳过
        for(int presentGrop=groupMax;presentGrop>=1;presentGrop--){
            if(sum%presentGrop!=0){
                continue;
            }
            //temp[i]表示value[i]在分完组后的第几组。初始为0表示value[i]还没有被分过
            for(int j=0;j<l;j++){
                temp[j]=0;
            }
            if(judge(values,temp,presentGrop,sum/presentGrop,sum/presentGrop,1)) {
                return sum/presentGrop;
            }
        }
        return -1;
    }
    /**判断能否成功分组
    *temp[i]表示value[i]在分完组后的第几组,每一个value[i]都对应一个temp[i]
    *presentGrop表示一共被分为几组,targetTotal表示每一组的和
    *groupId表示被分到第几组,属于区间[1,presentGrop],total表示目前第groupId组里面还需要填充的值
    */
    public boolean judge(int[] values,int[] temp,int presentGrop,int targetTotal,int total,int groupId){
        if(total<0){
            return false;
        }
        if(total==0){//表示第groupId组已经分配完毕
            groupId++;//需要分配下一组
            total=targetTotal;//下一组还未开始分配,需要填充的值重置为targetTotal
            if(groupId==presentGrop+1){//表示所有组都分配完成
                return true;
            }
        }
        for(int i=0;i<values.length;i++){
            if(temp[i]!=0){//表示value[i]已经分配过了,跳过
                continue;
            }
            temp[i]=groupId;//尝试分配value[i]到第groupId组
            if(judge(values,temp,presentGrop,targetTotal,total-values[i],groupId)){//判断分配完该value[i]后能否成功分组,只需改变total的值=total-values[i]
                return true;
            }
            temp[i]=0;//不能成功分组,把value[i]置为未分配过
        }
        return false;
    }

}

你可能感兴趣的:(算法,java,开发语言)