题解

难度:简单

知识点:数学问题

分析:

在本题中,踢赢比赛得一分,输了不等分也不见分,
那么(1)总分一定等于n;同时要想是平局n%3=0;(2)还没有踢的比赛(n-k),要能弥补(d1+d2)的分数差,即n-k≥d1+d2;(3)满足以上两点的情况时,根据差值情况,有4种情况,如下:
“1队>2队或1队<2队“ 与 “2队>3队或2队<3队”组合,假设1队的得分情况是m。
① 当1队>2队,2队>3队时,3支队伍的得分情况是:
m(max)
m-d1
m-d1-d2(min)  k=3m-2d1-d2
在该情况下,1队得分最多,3队得分最少。
要想达到平局,必须追上1队的成绩,至少还需要进行“2d1+d2”场比赛,所以剩下的场次(n-k)≤(2d1+d2),并且剩下的场次仍能被3平分才能继续保持平局。

② 当1队>2队,2队<3队时,3支队伍的得分情况是:
m
m-d1(min)
m-d1+d2  k=3m-2d1+d2
在该情况下,1队3队得分最多的要看d1d2的大小,2队得分最少。
当d1≥d2时,1队的得分最多;此时要想追上1队的成绩需要“2d1-d2”场,则(n-k)≤(2d1-d2)
否则3队得分最多, 此时要想追上3队的成绩需要“2d2-d1”场,则(n-k)≤(2d2-d1)

③ 当1队<2队,2队>3队时,3支队伍的得分情况是:
m
m+d1(max)
m+d1-d2  k=3m+2d1-d2
在该情况下,2队得分最多,1队3队得分最少要看d1d2的大小。
当d1≥d2时,1队的得分最少;否则3队得分最少。
要想达到平局,必须追上2队的成绩,至少还需要进行“d1+d2”场比赛,所以剩下的场次(n-k)≤(d1+d2)。

④ 当1队>2队,2队<3队时,3支队伍的得分情况是:
m(min)
m+d1
m+d1+d2(max)  k=3m+2d1+d2
在该情况下,1队得分最少,3队得分最多。
要想达到平局,必须追上3队的成绩,至少还需要进行“d1+2d2”场比赛,所以剩下的场次(n-k)≤(d1+2d2)。
不管在哪种情况下,要想达到平局,最后任意一个队伍的得分一定不能超过n/3。
通过上面的分析,可以有2种解题方法:利用剩余场次,以及利用最高队伍的得分情况,而这两种方法的大前提都是第一队m(基础)有解才可以。

方法1:利用最高得分列关系式

import java.util.Scanner;

public class Main{
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
            int t = Integer.parseInt(sc.nextLine());

            for(int i=0;i<t;i++){
                String s = sc.nextLine();
                String[] ss = s.split(" ");
                long n = Long.parseLong(ss[0]);
                long k = Long.parseLong(ss[1]);
                long d1 = Long.parseLong(ss[2]);
                long d2 = Long.parseLong(ss[3]);

                // 利用最高分解决
                String res = solve(n,k,d1,d2);

                System.out.println(res);
            }

    }


    private static String solve(long n, long k, long d1, long d2) {

                if(n%3!=0 || n-k < d1+d2 ){
                    return "no";
                }

                // 因为是以第一队为基础,所以第一队有解是大前提。
           // 第1种情况下的1队得分最多,
           long m1 = k + 2*d1 + d2;


           // 第2种情况下的最多得分队伍
           long m2 = 0;
           if (d1>=d2){
               m2 = k+2*d1-d2; //1队大
           }else{
               m2 = k-d1+2*d2;  //3队大
           }
           long m2m = k+2*d1-d2; // 此时1队得分

           //第3种情况下,2队得分最多
           long m3 = k+d1+d2;
           long m3m = k-2*d1+d2;  // 此时1队得分

           //第4种情况下3队得分最多
           long m4 = k+d1+2*d2;
           long m4m = k-2*d1-d2;  //此时1队得分


           if((m1>=0 && m1%3==0 && m1/3<=n/3) 
                   || (m2>=0 && m2%3==0 && m2/3<=n/3 && m2m>=0 && m2m%3==0) 
                   || (m3>=0 && m3%3==0 && m3/3<=n/3 && m3m>=0 && m3m%3==0) 
                   || (m4>=0 && m4%3==0 && m4/3<=n/3 && m4m>=0 && m4m%3==0)){
               return "yes";
           }

            return "no";
    }
}

方法2:利用利用剩余场次列关系式

import java.util.Scanner;
public class Main{
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
            int t = Integer.parseInt(sc.nextLine());

            for(int i=0;i<t;i++){
                String s = sc.nextLine();
                String[] ss = s.split(" ");
                long n = Long.parseLong(ss[0]);
                long k = Long.parseLong(ss[1]);
                long d1 = Long.parseLong(ss[2]);
                long d2 = Long.parseLong(ss[3]);

                // 利用剩余比赛场次解决
            String res = solve2(n,k,d1,d2);

                System.out.println(res);
            }

    }

    private static String solve2(long n, long k, long d1, long d2) {
            long m1 = k + 2*d1 + d2;  //情况1
            if(m1 >= 0 && m1 % 3 == 0){ //m有解是大前提
                long left = (n - k) - (2*d1  + d2);  //需要2d1+d2才能让两个较低的追上最高的达到平局,
                if(left >= 0 && left % 3 == 0){ //那么剩下的场次要继续能被3整除才能继续保持平局。
                    return "yes";

                }
            }

            long m2 = k + 2*d1 - d2;//情况2
            if(m2 >= 0 && m2 % 3 == 0){
            long left;
                if(d1 >= d2){
                    left = (n - k) - (2*d1 - d2);
                }else{
                    left = (n - k) - (2*d2 - d1);
                }

                if(left >= 0 && left % 3 == 0){
                    return "yes";
                }
            }

            long m3 = k - 2*d1  + d2; //情况3
            if(m3 >= 0 && m3 % 3 == 0){
                long left = (n - k) - (d1 + d2);
                if(left >= 0 && left % 3 == 0){
                    return "yes";
                }
            }

            long m4 = k - 2* d1 - d2; //情况4    
            if(m4 >= 0 && m4 % 3 == 0){ 
                long left = (n - k) - (d1 + 2*d2 );
                if(left >= 0 && left % 3 == 0){  
                    return "yes";
                }
            }

        return "no";
    }

}