华为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;
    }

}
MVP争夺战是一道华为OD题,要求使用Java语言实现。MVP模式是一种经典的软件架构模式,它将应用程序分成三个部分:模型(Model)、视图(View)、控制器(Presenter)。通过构建这种模式,可以使应用程序更易于维护和测,并且不同的部分可以独立开发MVP争夺战要求实现一个简单的场景,其中有两个队伍:蓝队和红队。选手可以选择加入其中一个队伍。每个队伍会派出若干个选手进行争夺战,战斗时间为30秒。每个选手都有一定的攻击力和生命值。获胜的队伍将获得胜利,获胜选手的攻击力和生命值还会有所提升。 为了实现这个场景,我们可以采用MVP模式进行设计。首先,我们需要定义Model类来表示选手,其中包括选手的攻击力和生命值等属性。然后,我们需要定义View类来显示游戏场景,例如显示两个队伍的选手列表、选手的属性等信息。最后,我们需要定义Presenter类来协调Model和View之间的交互,例如当选手攻击时,Presenter需要计算选手的伤害值,并更新选手的生命值,最后将更新后的结果显示在View上。 使用MVP模式设计程序,可以使程序的各个部分高度耦合,并且易于扩展和调。此外,该设计模式还可以使开发者更好地组织代码,使代码更加清晰易懂。在实现时,需要注意各个部分的交互和数据流的控制,确保程序的正确性和功能完整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值