-
Notifications
You must be signed in to change notification settings - Fork 3
Jyj1289 #1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: jyj1289
Are you sure you want to change the base?
Jyj1289 #1
Changes from 10 commits
d24a3ce
86c0923
35584e3
85e75c3
46577a0
90d38d5
f0e8a65
93f5be1
32c3fe1
7e0c692
599bca9
20436ef
11b202f
dc46d38
d790e2d
ebf0a55
b06610e
8a0bce7
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,23 @@ | ||
| import java.util.Random; | ||
|
|
||
| public class Attacker extends Soccer{ | ||
| Attacker(String name){ | ||
| super(name); | ||
| } | ||
|
|
||
| @Override | ||
| public boolean shoot(Keeper keeper){ | ||
| Random random = new Random(); | ||
|
|
||
| int shoot1 = random.nextInt(11); | ||
| int shoot2 = random.nextInt(11); | ||
|
|
||
| if (keeper.block(shoot1) || keeper.block(shoot2)){ | ||
| goal(); | ||
| } | ||
|
|
||
| print(getScore()); | ||
|
|
||
| return true; | ||
| } | ||
| } | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,28 @@ | ||
| import java.util.Random; | ||
|
|
||
| public class Keeper extends Soccer{ | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 굳이 Keeper가 Soccer를 상속받을 필요는 없습니다. |
||
| private int keep_count = 3; | ||
| private boolean check = false; | ||
| Keeper(String name){ | ||
| super(name); | ||
| } | ||
|
|
||
| public boolean shoot(Keeper keeper){ | ||
| return false; | ||
| } | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 이런 로직이 굳이 상속을 받아서 생긴 것이죠. |
||
|
|
||
| public boolean block(int shoot){ | ||
| Random random = new Random(); | ||
| int blockShoot = random.nextInt(5) + 3; | ||
| if (shoot >= 2 && shoot <= 7 && keep_count > 0){ | ||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. keep_count가 왜 필요한가요? |
||
| keep_count -= 1; | ||
| return shoot != blockShoot; | ||
| } | ||
| if (shoot >= 2 && shoot <= 8){ | ||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 이 코드의 이유가 있을까요? |
||
| return true; | ||
| } | ||
| return false; | ||
| } | ||
|
|
||
|
|
||
| } | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,23 @@ | ||
| import java.util.Random; | ||
|
|
||
| public class Midfielder extends Soccer { | ||
| Midfielder(String name) { | ||
| super(name); | ||
| } | ||
|
|
||
| public boolean shoot(Keeper keeper) { | ||
| Random random = new Random(); | ||
|
|
||
| int shoot = random.nextInt(11); | ||
|
|
||
| boolean shootBool = keeper.block(shoot); | ||
|
|
||
| if (shootBool){ | ||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 이럴떄는 변수에 할당을 안하고 사용할 수 있어요! |
||
| goal(); | ||
| } | ||
|
|
||
| print(getScore()); | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 공격수도 그렇고 print(getScore())라는 로직을 가지고 있는데, printScore()메서드를 만드는 것이 더 효율적이고, 깔끔한 것 같습니다. |
||
|
|
||
| return true; | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 의미 없는 리턴은 없어야합니다. |
||
| } | ||
| } | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,27 @@ | ||
| public abstract class Soccer{ | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Soccer라는 네이밍에 대해서 고민해봐야할 것 같아요. Soccer가 뭐죠? |
||
| private String name; | ||
| private int score; | ||
|
|
||
| Soccer(String name){ | ||
| this.name = name; | ||
| this.score = 0; | ||
| } | ||
| public String getName(){ | ||
| return name; | ||
| } | ||
|
|
||
| public void goal(){ | ||
| this.score += 1; | ||
| } | ||
|
|
||
| abstract boolean shoot(Keeper keeper); | ||
|
|
||
| public int getScore() { return score; } | ||
|
|
||
| public void print(int score){ | ||
| for(int i = 0; i < score; i++){ | ||
| System.out.print("-"); | ||
| } | ||
| } | ||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 추상클래스를 잘 이해하고 계신거 같습니다~ 👍 |
||
|
|
||
| } | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -1,5 +1,77 @@ | ||
| import javax.accessibility.AccessibleTable; | ||
| import java.util.Scanner; | ||
|
|
||
| public class SoccerGameApplication { | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 이 클래스의 책임이 너무 많은 것 같아요. 작게는 문자를 출력하는 것부터, 크게는 핵심 로직까지 다 이 클래스가 책임지고 있습니다. |
||
| public static void main(String[] args) { | ||
| String[] names = inputNames("공격수"); | ||
| Attacker attacker1 = new Attacker(names[0]); | ||
| Attacker attacker2 = new Attacker(names[1]); | ||
|
|
||
| names = inputNames("미드필더"); | ||
| Midfielder midfielder1 = new Midfielder(names[0]); | ||
| Midfielder midfielder2 = new Midfielder(names[1]); | ||
|
|
||
| names = inputNames("골키퍼"); | ||
| Keeper keeper = new Keeper(names[0]); | ||
|
|
||
| int matchPoint = inputMatchPoint(); | ||
| boolean bool = true; | ||
|
|
||
| int count = 1; | ||
|
|
||
| Soccer[] soccers = new Soccer[] {attacker1, attacker2, midfielder1, midfielder2}; | ||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. List 형태면 더 좋을것 같습니다 |
||
|
|
||
| while(bool){ | ||
| System.out.printf("\n%d번째 슈팅결과", count); | ||
| printResult(soccers, keeper); | ||
| count++; | ||
| bool = check(attacker1, attacker2, midfielder1, midfielder2, matchPoint); | ||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. List로 받아보세요! |
||
| } | ||
|
|
||
| } | ||
|
|
||
| static String[] inputNames(String position){ | ||
| Scanner sc = new Scanner(System.in); | ||
| System.out.printf("%s의 이름을 입력하세요 : ", position); | ||
| String[] names = sc.nextLine().split(", "); | ||
|
|
||
| return names; | ||
| } | ||
|
|
||
| static int inputMatchPoint(){ | ||
| Scanner sc = new Scanner(System.in); | ||
| System.out.print("매치포인트를 입력하세요 : "); | ||
|
|
||
| int matchPoint = sc.nextInt(); | ||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. matchPoint선언한 이유가 있나요? |
||
|
|
||
| return matchPoint; | ||
| } | ||
|
|
||
| static boolean check(Attacker attacker1, Attacker attacker2, Midfielder midfielder1, Midfielder midfielder2 ,int matchPoint){ | ||
|
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Player배열을 사용하는 것이 어떨까요? |
||
| if (attacker1.getScore() == matchPoint){ | ||
| System.out.printf("\n\n승리자는 %s 입니다.", attacker1.getName()); | ||
| return false; | ||
| } | ||
| if (attacker2.getScore() == matchPoint){ | ||
| System.out.printf("\n\n승리자는 %s 입니다.", attacker2.getName()); | ||
| return false; | ||
| } | ||
| if (midfielder1.getScore() == matchPoint){ | ||
| System.out.printf("\n\n승리자는 %s 입니다.", midfielder1.getName()); | ||
| return false; | ||
| } | ||
| if (midfielder2.getScore() == matchPoint){ | ||
| System.out.printf("\n\n승리자는 %s 입니다.", midfielder2.getName()); | ||
| return false; | ||
| } | ||
| return true; | ||
| } | ||
|
|
||
| static void printResult(Soccer[] soccers, Keeper keeper){ | ||
| for (Soccer soccer : soccers){ | ||
| System.out.printf("\n%s: ", soccer.getName()); | ||
| soccer.shoot(keeper); | ||
| } | ||
| } | ||
|
|
||
| } | ||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
항상 true가 반환 된다면 그냥 void함수가 좋지 않을까요?