diff options
| author | Tyler Ferrari <69283684+Sowgro@users.noreply.github.com> | 2025-11-16 02:16:38 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-11-16 02:16:38 -0500 |
| commit | 73dfd2dd419483c7d1060ef2fb40e328a0209e02 (patch) | |
| tree | 456ed56e629a6324e5993b7ce094705c72e0b922 /src/main/java/design/model/Team.java | |
| parent | b5d46c7701716bcb2dd6127aeb97f8fcdb7774fc (diff) | |
| parent | 6ffc6b4cbd9e0c5ce2dc82a7c77f39b3adf849b6 (diff) | |
| download | designproject-design-6-73dfd2dd419483c7d1060ef2fb40e328a0209e02.tar.gz designproject-design-6-73dfd2dd419483c7d1060ef2fb40e328a0209e02.tar.bz2 designproject-design-6-73dfd2dd419483c7d1060ef2fb40e328a0209e02.zip | |
Merge pull request #21 from RIT-SWEN-262/league-model
League model
Diffstat (limited to 'src/main/java/design/model/Team.java')
| -rw-r--r-- | src/main/java/design/model/Team.java | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/src/main/java/design/model/Team.java b/src/main/java/design/model/Team.java index 53b276e..8f30468 100644 --- a/src/main/java/design/model/Team.java +++ b/src/main/java/design/model/Team.java @@ -1,17 +1,22 @@ package design.model; import java.util.ArrayList; +import java.util.HashMap; import java.util.List; +import java.util.Map; +import java.util.Objects; public class Team { private String name; private final List<Golfer> members; + private final Map<Golfer, Integer> memberBestRounds; private final Golfer owner; public Team(String name, Golfer owner) { this.name = name; this.owner = owner; this.members = new ArrayList<>(); + this.memberBestRounds = new HashMap<>(); } public String getName() { @@ -27,14 +32,40 @@ public class Team { } public boolean addMember(Golfer golfer) { + if(members.size() >= 4){ + throw new IllegalArgumentException("Team size limit reached!"); + } return members.add(golfer); } public boolean removeMember(Golfer g) { + memberBestRounds.remove(g); return members.remove(g); } public Golfer getOwner() { return owner; } + + public void addMemberRound(Golfer g, int strokes){ + memberBestRounds.merge(g, strokes, Math::min); + } + + public int computeTotalBestScore(){ + if(memberBestRounds.isEmpty()) return 100; // Bad Score Penalty for not playing + return memberBestRounds.values().stream().min(Integer::compareTo).orElse(100); + } + + @Override + public boolean equals(Object obj) { + if (this == obj) return true; + if (obj == null || getClass() != obj.getClass()) return false; + Team other = (Team) obj; + return Objects.equals(name, other.name) && Objects.equals(owner, other.owner); + } + + @Override + public int hashCode() { + return Objects.hash(name, owner); + } } |
