summaryrefslogtreecommitdiff
path: root/src/Q8/BadmintonScoring.java
blob: 927f417b7525bf609617e164d6023ea4ed2e4132 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
package Q8;

import java.util.*;

public class BadmintonScoring {
  protected int[][] scores;
  private static final int PLAYER1 = 0;
  private static final int PLAYER2 = 1;

  public BadmintonScoring(int[][] scores) {
    this.scores = scores;
  }

  public int getContinuousPointsPlayer1() {
    return this.longestStreakFor(PLAYER1);
  }

  public int getContinuousPointsPlayer2() {
    return this.longestStreakFor(PLAYER2);
  }

  public int getPlayer1Points() {
    return this.finalScoreFor(PLAYER1);
  }

  public int getPlayer2Points() {
    return this.finalScoreFor(PLAYER2);
  }

  private int finalScoreFor(int player) {
    int finalScore = 0;
    for (int[] items : scores) finalScore = items[player];
    return finalScore;
  }

  private int longestStreakFor(int player) {
    int streak = 0;
    int longestStreak = 0;
    boolean lastWinner = false;

    for (int i = 0; i < scores.length; i++) {
      int score = scores[i][player];
      int previousScore = i == 0 ? -1 : scores[i - 1][player];
      boolean winner = score > previousScore;

      if (winner && lastWinner) {
        streak++;
        longestStreak = (streak > longestStreak) ? streak : longestStreak;
      } else streak = 0;

      lastWinner = winner;
    }

    return longestStreak;
  }

  private int winnerOf(int round) {
    int player1Score = scores[round][0];
    int player1PreviousScore = scores[round - 1][0];
    return player1Score > player1PreviousScore ? PLAYER1 : PLAYER2;
  }
}