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