From b4a487e9a569ddff1d0f15c0a7f05380b2dd527d Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 20:52:26 +0900 Subject: [PATCH 01/15] Update README.md --- README.md | 186 +++++++----------------------------------------------- 1 file changed, 23 insertions(+), 163 deletions(-) diff --git a/README.md b/README.md index a2b6ed1440..fa8bcacb60 100644 --- a/README.md +++ b/README.md @@ -1,164 +1,24 @@ -# java-racingcar-precourse -# 미션 - 자동차 경주 +# java-racingcar-precourse 기능 목록 + +## InputView: 입력 받기 + +## **RacingCarService: winners 리스트 반환** + +- 입력 검증(CarNameVerifier, RoundVerifier) + - CarNameVerifier: + - 예외: strip → 이름.length() > 5 + - 예외: isblank + - RoundVerifier: + - 예외: 숫자가 아닌 값이 들어올 때 + - ~~예외: 횟수가 int 범위를 벗어날 때~~ 상식적으로 게임 라운드가 int범위를 넘기지 않을 거라고 판단. + - 예외: 음수일 때 +- Car 생성 +- ‘실행 결과' 출력 - 이거 Racing에 들어있으면 좋겠는데 +- **Racing - 여기도 좀 리팩토링 하고 싶은데** + - round만큼 반복 + - RandomMover + - 라운드 별 실행 결과 출력 +- WinnersFinder + +## ResultView -## 🔍 진행 방식 - -- 미션은 **기능 요구 사항, 프로그래밍 요구 사항, 과제 진행 요구 사항** 세 가지로 구성되어 있다. -- 세 개의 요구 사항을 만족하기 위해 노력한다. 특히 기능을 구현하기 전에 기능 목록을 만들고, 기능 단위로 커밋 하는 방식으로 진행한다. -- 기능 요구 사항에 기재되지 않은 내용은 스스로 판단하여 구현한다. - -## 📮 미션 제출 방법 - -- 미션 구현을 완료한 후 GitHub을 통해 제출해야 한다. - - GitHub을 활용한 제출 방법은 [프리코스 과제 제출](https://github.com/woowacourse/woowacourse-docs/tree/master/precourse) 문서를 참고해 제출한다. -- GitHub에 미션을 제출한 후 [우아한테크코스 지원](https://apply.techcourse.co.kr) 사이트에 접속하여 프리코스 과제를 제출한다. - - 자세한 방법은 [제출 가이드](https://github.com/woowacourse/woowacourse-docs/tree/master/precourse#제출-가이드) 참고 - - **Pull Request만 보내고 지원 플랫폼에서 과제를 제출하지 않으면 최종 제출하지 않은 것으로 처리되니 주의한다.** - -## 🚨 과제 제출 전 체크 리스트 - 0점 방지 - -- 기능 구현을 모두 정상적으로 했더라도 **요구 사항에 명시된 출력값 형식을 지키지 않을 경우 0점으로 처리**한다. -- 기능 구현을 완료한 뒤 아래 가이드에 따라 테스트를 실행했을 때 모든 테스트가 성공하는지 확인한다. -- **테스트가 실패할 경우 0점으로 처리**되므로, 반드시 확인 후 제출한다. - -### 테스트 실행 가이드 - -- 터미널에서 `java -version`을 실행하여 Java 버전이 17인지 확인한다. - Eclipse 또는 IntelliJ IDEA와 같은 IDE에서 Java 17로 실행되는지 확인한다. -- 터미널에서 Mac 또는 Linux 사용자의 경우 `./gradlew clean test` 명령을 실행하고, - Windows 사용자의 경우 `gradlew.bat clean test` 또는 `./gradlew.bat clean test` 명령을 실행할 때 모든 테스트가 아래와 같이 통과하는지 확인한다. - -``` -BUILD SUCCESSFUL in 0s -``` - ---- - -## 🚀 기능 요구 사항 - -초간단 자동차 경주 게임을 구현한다. - -- 주어진 횟수 동안 n대의 자동차는 전진 또는 멈출 수 있다. -- 각 자동차에 이름을 부여할 수 있다. 전진하는 자동차를 출력할 때 자동차 이름을 같이 출력한다. -- 자동차 이름은 쉼표(,)를 기준으로 구분하며 이름은 5자 이하만 가능하다. -- 사용자는 몇 번의 이동을 할 것인지를 입력할 수 있어야 한다. -- 전진하는 조건은 0에서 9 사이에서 무작위 값을 구한 후 무작위 값이 4 이상일 경우이다. -- 자동차 경주 게임을 완료한 후 누가 우승했는지를 알려준다. 우승자는 한 명 이상일 수 있다. -- 우승자가 여러 명일 경우 쉼표(,)를 이용하여 구분한다. -- 사용자가 잘못된 값을 입력할 경우 `IllegalArgumentException`을 발생시킨 후 애플리케이션은 종료되어야 한다. - -### 입출력 요구 사항 - -#### 입력 - -- 경주 할 자동차 이름(이름은 쉼표(,) 기준으로 구분) - -``` -pobi,woni,jun -``` - -- 시도할 회수 - -``` -5 -``` - -#### 출력 - -- 각 차수별 실행 결과 - -``` -pobi : -- -woni : ---- -jun : --- -``` - -- 단독 우승자 안내 문구 - -``` -최종 우승자 : pobi -``` - -- 공동 우승자 안내 문구 - -``` -최종 우승자 : pobi, jun -``` - -#### 실행 결과 예시 - -``` -경주할 자동차 이름을 입력하세요.(이름은 쉼표(,) 기준으로 구분) -pobi,woni,jun -시도할 회수는 몇회인가요? -5 - -실행 결과 -pobi : - -woni : -jun : - - -pobi : -- -woni : - -jun : -- - -pobi : --- -woni : -- -jun : --- - -pobi : ---- -woni : --- -jun : ---- - -pobi : ----- -woni : ---- -jun : ----- - -최종 우승자 : pobi, jun -``` - ---- - -## 🎯 프로그래밍 요구 사항 - -- JDK 17 버전에서 실행 가능해야 한다. **JDK 17에서 정상적으로 동작하지 않을 경우 0점 처리한다.** -- 프로그램 실행의 시작점은 `Application`의 `main()`이다. -- `build.gradle` 파일을 변경할 수 없고, 외부 라이브러리를 사용하지 않는다. -- [Java 코드 컨벤션](https://github.com/woowacourse/woowacourse-docs/tree/master/styleguide/java) 가이드를 준수하며 프로그래밍한다. -- 프로그램 종료 시 `System.exit()`를 호출하지 않는다. -- 프로그램 구현이 완료되면 `ApplicationTest`의 모든 테스트가 성공해야 한다. **테스트가 실패할 경우 0점 처리한다.** -- 프로그래밍 요구 사항에서 달리 명시하지 않는 한 파일, 패키지 이름을 수정하거나 이동하지 않는다. - -### 추가된 요구 사항 - -- indent(인덴트, 들여쓰기) depth를 3이 넘지 않도록 구현한다. 2까지만 허용한다. - - 예를 들어 while문 안에 if문이 있으면 들여쓰기는 2이다. - - 힌트: indent(인덴트, 들여쓰기) depth를 줄이는 좋은 방법은 함수(또는 메서드)를 분리하면 된다. -- 3항 연산자를 쓰지 않는다. -- 함수(또는 메서드)가 한 가지 일만 하도록 최대한 작게 만들어라. -- JUnit 5와 AssertJ를 이용하여 본인이 정리한 기능 목록이 정상 동작함을 테스트 코드로 확인한다. - - 테스트 도구 사용법이 익숙하지 않다면 `test/java/study`를 참고하여 학습한 후 테스트를 구현한다. - -### 라이브러리 - -- JDK에서 제공하는 Random 및 Scanner API 대신 `camp.nextstep.edu.missionutils`에서 제공하는 `Randoms` 및 `Console` API를 사용하여 구현해야 한다. - - Random 값 추출은 `camp.nextstep.edu.missionutils.Randoms`의 `pickNumberInRange()`를 활용한다. - - 사용자가 입력하는 값은 `camp.nextstep.edu.missionutils.Console`의 `readLine()`을 활용한다. - -#### 사용 예시 - -- 0에서 9까지의 정수 중 한 개의 정수 반환 - -```java -Randoms.pickNumberInRange(0,9); -``` - ---- - -## ✏️ 과제 진행 요구 사항 - -- 미션은 [java-racingcar-7](https://github.com/woowacourse-precourse/java-racingcar-7) 저장소를 Fork & Clone해 시작한다. -- **기능을 구현하기 전 `docs/README.md`에 구현할 기능 목록을 정리**해 추가한다. -- **Git의 커밋 단위는 앞 단계에서 `docs/README.md`에 정리한 기능 목록 단위**로 추가한다. - - [커밋 메시지 컨벤션](https://gist.github.com/stephenparish/9941e89d80e2bc58a153) 가이드를 참고해 커밋 메시지를 작성한다. -- 과제 진행 및 제출 방법은 [프리코스 과제 제출](https://github.com/woowacourse/woowacourse-docs/tree/master/precourse) 문서를 참고한다. From 8b24bc7e4c42bf3168f72fd5e1f67feaba965368 Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 22:17:46 +0900 Subject: [PATCH 02/15] =?UTF-8?q?feat($RacingCarController):=20=EC=BB=A8?= =?UTF-8?q?=ED=8A=B8=EB=A1=A4=EB=9F=AC=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/racingcar/Application.java | 4 ++++ .../racingcar/controller/RacingCarController.java | 15 +++++++++++++++ 2 files changed, 19 insertions(+) create mode 100644 src/main/java/racingcar/controller/RacingCarController.java diff --git a/src/main/java/racingcar/Application.java b/src/main/java/racingcar/Application.java index a17a52e724..92d8a6dd82 100644 --- a/src/main/java/racingcar/Application.java +++ b/src/main/java/racingcar/Application.java @@ -1,7 +1,11 @@ package racingcar; +import racingcar.controller.RacingCarController; + public class Application { public static void main(String[] args) { // TODO: 프로그램 구현 + RacingCarController racingCarController = new RacingCarController(); + racingCarController.run(); } } diff --git a/src/main/java/racingcar/controller/RacingCarController.java b/src/main/java/racingcar/controller/RacingCarController.java new file mode 100644 index 0000000000..564c6c9771 --- /dev/null +++ b/src/main/java/racingcar/controller/RacingCarController.java @@ -0,0 +1,15 @@ +package racingcar.controller; + +import racingcar.service.RacingCarService; +import racingcar.view.InputView; +import racingcar.view.ResultView; + +public class RacingCarController { + private final InputView inputView = new InputView(); + private final RacingCarService racingCarService = new RacingCarService(); + private final ResultView resultView = new ResultView(); + + public void run(){ + resultView.printResult(racingCarService.playRacingCar(inputView.readCarNames(), inputView.readRound())); + } +} From a75a0319da276b98042f1b77719781af8eec39df Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 22:18:13 +0900 Subject: [PATCH 03/15] =?UTF-8?q?feat($view):=20=EC=82=AC=EC=9A=A9?= =?UTF-8?q?=EC=9E=90=20=EC=9E=85=EB=A0=A5=20=EC=B2=98=EB=A6=AC=20=EB=B0=8F?= =?UTF-8?q?=20=EA=B2=B0=EA=B3=BC=20=EC=B6=9C=EB=A0=A5=20=EA=B8=B0=EB=8A=A5?= =?UTF-8?q?=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/racingcar/view/InputView.java | 25 ++++++++++++++++++++ src/main/java/racingcar/view/ResultView.java | 21 ++++++++++++++++ 2 files changed, 46 insertions(+) create mode 100644 src/main/java/racingcar/view/InputView.java create mode 100644 src/main/java/racingcar/view/ResultView.java diff --git a/src/main/java/racingcar/view/InputView.java b/src/main/java/racingcar/view/InputView.java new file mode 100644 index 0000000000..5a09eebb12 --- /dev/null +++ b/src/main/java/racingcar/view/InputView.java @@ -0,0 +1,25 @@ +package racingcar.view; + +import camp.nextstep.edu.missionutils.Console; + +public class InputView { + private static final String CARNAMES_INPUT_MSG = "경주할 자동차 이름을 입력하세요.(이름은 쉼표(,) 기준으로 구분)"; + private static final String ROUND_INPUT_MSG = "시도할 회수는 몇회인가요?"; + + public String readCarNames() { + System.out.println(CARNAMES_INPUT_MSG); + return Console.readLine().strip(); + } + + public int readRound(){ + System.out.println(ROUND_INPUT_MSG); + String roundString = Console.readLine().strip(); + + try { + return Integer.parseInt(roundString); + } catch (NumberFormatException e) { + throw new IllegalArgumentException("[ERROR] 숫자만 입력할 수 있습니다."); + } + + } +} diff --git a/src/main/java/racingcar/view/ResultView.java b/src/main/java/racingcar/view/ResultView.java new file mode 100644 index 0000000000..52e61176d7 --- /dev/null +++ b/src/main/java/racingcar/view/ResultView.java @@ -0,0 +1,21 @@ +package racingcar.view; + +import racingcar.domain.Car; + +import java.util.List; + +public class ResultView { + private static final String RESULT_MSG = "최종 우승자 : "; + + public void printResult(List winners) { + StringBuilder resultString = new StringBuilder(RESULT_MSG); + + // 람다로 써보기 + for(int i=0; i Date: Sat, 27 Sep 2025 22:18:56 +0900 Subject: [PATCH 04/15] =?UTF-8?q?feat($controller):=20RacingCarService=20?= =?UTF-8?q?=EC=83=9D=EC=84=B1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../racingcar/service/RacingCarService.java | 62 +++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 src/main/java/racingcar/service/RacingCarService.java diff --git a/src/main/java/racingcar/service/RacingCarService.java b/src/main/java/racingcar/service/RacingCarService.java new file mode 100644 index 0000000000..5d45a8a185 --- /dev/null +++ b/src/main/java/racingcar/service/RacingCarService.java @@ -0,0 +1,62 @@ +package racingcar.service; + +/* +* 입력 검증(CarNameVerifier, RoundVerifier) +CarNameVerifier: +예외: strip → 이름.length() > 5 +예외: isblank +RoundVerifier: +예외: 숫자가 아닌 값이 들어올 때 +예외: 음수일 때 +Car 생성 +‘실행 결과' 출력 - 이거 Racing에 들어있으면 좋겠는데 +Racing - 여기도 좀 리팩토링 하고 싶은데 +round만큼 반복 +RandomMover +라운드 별 실행 결과 출력 +WinnersFinder +*/ + +import racingcar.domain.Car; +import racingcar.domain.CarNameVerifier; +import racingcar.domain.RoundVerifier; +import camp.nextstep.edu.missionutils.Randoms; +import racingcar.domain.WinnersFinder; + +import java.util.ArrayList; +import java.util.List; + +public class RacingCarService { + public static final String PLAY_MSG = "실행 결과"; + + public static final CarNameVerifier carNameVerifier = new CarNameVerifier(); + public static final RoundVerifier roundVerifier = new RoundVerifier(); + public static final WinnersFinder winnersFinder = new WinnersFinder(); + + public List playRacingCar(String rawCarNames, int rawRound) { + // CarNameVerifier + List carList = carNameVerifier.createCarList(rawCarNames); + + // RoundVerifier + int round = roundVerifier.getRound(rawRound); + + System.out.println(PLAY_MSG); + // Racing -> RandomMover + for(int i=0; i= 4){ + currentCar.move(); + } + System.out.print(currentCar.getCarName()+" : "); + + for(int j=0; j Date: Sat, 27 Sep 2025 22:19:54 +0900 Subject: [PATCH 05/15] =?UTF-8?q?feat($domain-car):=20Car=20=EB=8F=84?= =?UTF-8?q?=EB=A9=94=EC=9D=B8=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/racingcar/domain/Car.java | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 src/main/java/racingcar/domain/Car.java diff --git a/src/main/java/racingcar/domain/Car.java b/src/main/java/racingcar/domain/Car.java new file mode 100644 index 0000000000..34ce695c42 --- /dev/null +++ b/src/main/java/racingcar/domain/Car.java @@ -0,0 +1,23 @@ +package racingcar.domain; + +public class Car { + private String carName; + private int position; + + public Car(String carName) { + this.carName = carName; + this.position = 0; + } + + public String getCarName() { + return carName; + } + + public int getPosition() { + return position; + } + + public void move() { + position++; + } +} From 725734b6033cad4f6f901bd780259eb6f758dd74 Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 22:20:41 +0900 Subject: [PATCH 06/15] =?UTF-8?q?feat($domain-carnameverifier):=20CarNameV?= =?UTF-8?q?erifier=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../racingcar/domain/CarNameVerifier.java | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100644 src/main/java/racingcar/domain/CarNameVerifier.java diff --git a/src/main/java/racingcar/domain/CarNameVerifier.java b/src/main/java/racingcar/domain/CarNameVerifier.java new file mode 100644 index 0000000000..430b225f00 --- /dev/null +++ b/src/main/java/racingcar/domain/CarNameVerifier.java @@ -0,0 +1,29 @@ +package racingcar.domain; + +import java.util.ArrayList; +import java.util.List; + +// TODO: split 기능도 추가됨 -> 클래스명 바꾸거나 분리하기 +public class CarNameVerifier { + + public List createCarList(String rawStringOfCarNames) { + + List carList = new ArrayList<>(); + + if(rawStringOfCarNames == null || rawStringOfCarNames.isBlank()) { + throw new IllegalArgumentException("[ERROR] 공백은 안 받아요"); + } + + // CarNameVerifier + // "jenny "거나 " " + String[] carNamesArray = rawStringOfCarNames.split(","); + for(String carName : carNamesArray) { + if(carName.isBlank()) throw new IllegalArgumentException("[ERROR] 공백은 안 받아요"); + if(carName.length() > 5) throw new IllegalArgumentException("[ERROR] 이름이 5자를 초과해"); + carList.add(new Car(carName.strip())); + } + + return carList; + } + +} From 939de11b327596d980c17122a19809b8c1e36762 Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 22:21:09 +0900 Subject: [PATCH 07/15] =?UTF-8?q?feat($domain-roundverifier):=20RoundVerif?= =?UTF-8?q?ier=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/racingcar/domain/RoundVerifier.java | 10 ++++++++++ 1 file changed, 10 insertions(+) create mode 100644 src/main/java/racingcar/domain/RoundVerifier.java diff --git a/src/main/java/racingcar/domain/RoundVerifier.java b/src/main/java/racingcar/domain/RoundVerifier.java new file mode 100644 index 0000000000..f3dba1c238 --- /dev/null +++ b/src/main/java/racingcar/domain/RoundVerifier.java @@ -0,0 +1,10 @@ +package racingcar.domain; + +public class RoundVerifier { + + public int getRound(int rawRound){ + if(rawRound < 0) throw new IllegalArgumentException("[ERROR] 음수는 안 받아요"); + + return rawRound; + } +} From ef07c757afc7b06c8830a94f633c3630eb89fea7 Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 22:21:40 +0900 Subject: [PATCH 08/15] =?UTF-8?q?feat($domain-winnersfinder):=20WinnersFin?= =?UTF-8?q?der=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/racingcar/domain/WinnersFinder.java | 28 +++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 src/main/java/racingcar/domain/WinnersFinder.java diff --git a/src/main/java/racingcar/domain/WinnersFinder.java b/src/main/java/racingcar/domain/WinnersFinder.java new file mode 100644 index 0000000000..153a3e5c30 --- /dev/null +++ b/src/main/java/racingcar/domain/WinnersFinder.java @@ -0,0 +1,28 @@ +package racingcar.domain; + +/* +* position이 가장 먼 사람 찾기 +* */ + +import java.util.ArrayList; +import java.util.List; + +public class WinnersFinder { + public List findWinners(List cars) { + int maxPosition = 0; + List winners = new ArrayList<>(); + + for (Car car : cars) { + if(maxPosition < car.getPosition()){ + maxPosition = car.getPosition(); + winners.clear(); + winners.add(car); + } + else if(maxPosition == car.getPosition()){ + winners.add(car); + } + } + + return winners; + } +} From 990d13e04c0210a4f580383243545fc9c124e800 Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 22:31:16 +0900 Subject: [PATCH 09/15] =?UTF-8?q?refactor($domain,service):=20domain=20?= =?UTF-8?q?=ED=81=B4=EB=9E=98=EC=8A=A4=EB=AA=85,=20RacingCarService=20?= =?UTF-8?q?=EB=A9=94=EC=84=9C=EB=93=9C=EB=AA=85=20=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - `CarNameVerifier` → `CarNameValidator` - `RoundVerifier` → `RoundValidator` - `WinnersFinder` → `WinnerCalculator` - `RacingCarService.playRacingCar()` → `startRace()` --- .../racingcar/controller/RacingCarController.java | 2 +- ...CarNameVerifier.java => CarNameValidator.java} | 2 +- .../{RoundVerifier.java => RoundValidator.java} | 2 +- .../{WinnersFinder.java => WinnerCalculator.java} | 2 +- .../java/racingcar/service/RacingCarService.java | 15 +++++++-------- 5 files changed, 11 insertions(+), 12 deletions(-) rename src/main/java/racingcar/domain/{CarNameVerifier.java => CarNameValidator.java} (96%) rename src/main/java/racingcar/domain/{RoundVerifier.java => RoundValidator.java} (86%) rename src/main/java/racingcar/domain/{WinnersFinder.java => WinnerCalculator.java} (95%) diff --git a/src/main/java/racingcar/controller/RacingCarController.java b/src/main/java/racingcar/controller/RacingCarController.java index 564c6c9771..9409200fd9 100644 --- a/src/main/java/racingcar/controller/RacingCarController.java +++ b/src/main/java/racingcar/controller/RacingCarController.java @@ -10,6 +10,6 @@ public class RacingCarController { private final ResultView resultView = new ResultView(); public void run(){ - resultView.printResult(racingCarService.playRacingCar(inputView.readCarNames(), inputView.readRound())); + resultView.printResult(racingCarService.startRace(inputView.readCarNames(), inputView.readRound())); } } diff --git a/src/main/java/racingcar/domain/CarNameVerifier.java b/src/main/java/racingcar/domain/CarNameValidator.java similarity index 96% rename from src/main/java/racingcar/domain/CarNameVerifier.java rename to src/main/java/racingcar/domain/CarNameValidator.java index 430b225f00..22688fd783 100644 --- a/src/main/java/racingcar/domain/CarNameVerifier.java +++ b/src/main/java/racingcar/domain/CarNameValidator.java @@ -4,7 +4,7 @@ import java.util.List; // TODO: split 기능도 추가됨 -> 클래스명 바꾸거나 분리하기 -public class CarNameVerifier { +public class CarNameValidator { public List createCarList(String rawStringOfCarNames) { diff --git a/src/main/java/racingcar/domain/RoundVerifier.java b/src/main/java/racingcar/domain/RoundValidator.java similarity index 86% rename from src/main/java/racingcar/domain/RoundVerifier.java rename to src/main/java/racingcar/domain/RoundValidator.java index f3dba1c238..c455058f26 100644 --- a/src/main/java/racingcar/domain/RoundVerifier.java +++ b/src/main/java/racingcar/domain/RoundValidator.java @@ -1,6 +1,6 @@ package racingcar.domain; -public class RoundVerifier { +public class RoundValidator { public int getRound(int rawRound){ if(rawRound < 0) throw new IllegalArgumentException("[ERROR] 음수는 안 받아요"); diff --git a/src/main/java/racingcar/domain/WinnersFinder.java b/src/main/java/racingcar/domain/WinnerCalculator.java similarity index 95% rename from src/main/java/racingcar/domain/WinnersFinder.java rename to src/main/java/racingcar/domain/WinnerCalculator.java index 153a3e5c30..e492e1eb6f 100644 --- a/src/main/java/racingcar/domain/WinnersFinder.java +++ b/src/main/java/racingcar/domain/WinnerCalculator.java @@ -7,7 +7,7 @@ import java.util.ArrayList; import java.util.List; -public class WinnersFinder { +public class WinnerCalculator { public List findWinners(List cars) { int maxPosition = 0; List winners = new ArrayList<>(); diff --git a/src/main/java/racingcar/service/RacingCarService.java b/src/main/java/racingcar/service/RacingCarService.java index 5d45a8a185..73b6e6cf40 100644 --- a/src/main/java/racingcar/service/RacingCarService.java +++ b/src/main/java/racingcar/service/RacingCarService.java @@ -18,22 +18,21 @@ */ import racingcar.domain.Car; -import racingcar.domain.CarNameVerifier; -import racingcar.domain.RoundVerifier; +import racingcar.domain.CarNameValidator; +import racingcar.domain.RoundValidator; import camp.nextstep.edu.missionutils.Randoms; -import racingcar.domain.WinnersFinder; +import racingcar.domain.WinnerCalculator; -import java.util.ArrayList; import java.util.List; public class RacingCarService { public static final String PLAY_MSG = "실행 결과"; - public static final CarNameVerifier carNameVerifier = new CarNameVerifier(); - public static final RoundVerifier roundVerifier = new RoundVerifier(); - public static final WinnersFinder winnersFinder = new WinnersFinder(); + public static final CarNameValidator carNameVerifier = new CarNameValidator(); + public static final RoundValidator roundVerifier = new RoundValidator(); + public static final WinnerCalculator winnersFinder = new WinnerCalculator(); - public List playRacingCar(String rawCarNames, int rawRound) { + public List startRace(String rawCarNames, int rawRound) { // CarNameVerifier List carList = carNameVerifier.createCarList(rawCarNames); From dd930fbb2c6416ad7339ac15e4de79f845964fdb Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 22:49:43 +0900 Subject: [PATCH 10/15] =?UTF-8?q?refactor($winnercalculator):=20=EB=A9=94?= =?UTF-8?q?=EC=84=9C=EB=93=9C=20=EC=9D=B4=EB=A6=84=20=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/racingcar/domain/WinnerCalculator.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/racingcar/domain/WinnerCalculator.java b/src/main/java/racingcar/domain/WinnerCalculator.java index e492e1eb6f..5d0591ef42 100644 --- a/src/main/java/racingcar/domain/WinnerCalculator.java +++ b/src/main/java/racingcar/domain/WinnerCalculator.java @@ -8,7 +8,7 @@ import java.util.List; public class WinnerCalculator { - public List findWinners(List cars) { + public List calculate(List cars) { int maxPosition = 0; List winners = new ArrayList<>(); From b833cfab26580e946b3b0c6c98c1bde4329d3119 Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 22:51:05 +0900 Subject: [PATCH 11/15] =?UTF-8?q?refactor($carnamevalidator):=20=EC=BD=94?= =?UTF-8?q?=EB=93=9C=20=EA=B0=80=EB=8F=85=EC=84=B1=20=EA=B0=9C=EC=84=A0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/racingcar/domain/CarNameValidator.java | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/main/java/racingcar/domain/CarNameValidator.java b/src/main/java/racingcar/domain/CarNameValidator.java index 22688fd783..ad7f6fb8c0 100644 --- a/src/main/java/racingcar/domain/CarNameValidator.java +++ b/src/main/java/racingcar/domain/CarNameValidator.java @@ -18,9 +18,14 @@ public List createCarList(String rawStringOfCarNames) { // "jenny "거나 " " String[] carNamesArray = rawStringOfCarNames.split(","); for(String carName : carNamesArray) { - if(carName.isBlank()) throw new IllegalArgumentException("[ERROR] 공백은 안 받아요"); - if(carName.length() > 5) throw new IllegalArgumentException("[ERROR] 이름이 5자를 초과해"); - carList.add(new Car(carName.strip())); + String trimmed = carName.strip(); + if (trimmed.isBlank()) { + throw new IllegalArgumentException("[ERROR] 공백은 안 받아요"); + } + if (trimmed.length() > 5) { + throw new IllegalArgumentException("[ERROR] 이름이 5자를 초과해요"); + } + carList.add(new Car(trimmed)); } return carList; From 367aa148e4a38d825f956cb2d02972303d3e28e4 Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 22:52:34 +0900 Subject: [PATCH 12/15] =?UTF-8?q?refactor($reoundvalidator):=20=EA=B0=80?= =?UTF-8?q?=EB=8F=85=EC=84=B1=20=EA=B0=9C=EC=84=A0=20=EB=B0=8F=20=EB=A9=94?= =?UTF-8?q?=EC=84=9C=EB=93=9C=EB=AA=85=20=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/main/java/racingcar/domain/RoundValidator.java | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/main/java/racingcar/domain/RoundValidator.java b/src/main/java/racingcar/domain/RoundValidator.java index c455058f26..5798040c05 100644 --- a/src/main/java/racingcar/domain/RoundValidator.java +++ b/src/main/java/racingcar/domain/RoundValidator.java @@ -2,9 +2,10 @@ public class RoundValidator { - public int getRound(int rawRound){ - if(rawRound < 0) throw new IllegalArgumentException("[ERROR] 음수는 안 받아요"); - + public int validateRound(int rawRound){ + if (rawRound < 0) { + throw new IllegalArgumentException("[ERROR] 음수는 입력할 수 없습니다."); + } return rawRound; } } From 1674bfc35d2064b6eee601736d11390cdb456507 Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 22:54:48 +0900 Subject: [PATCH 13/15] =?UTF-8?q?refactor($service,domain):=20service?= =?UTF-8?q?=EC=99=80=20view=20=EB=B6=84=EB=A6=AC=20=EA=B0=9C=EC=84=A0=20?= =?UTF-8?q?=EB=B0=8F=20Mover=20=EC=9D=B8=ED=84=B0=ED=8E=98=EC=9D=B4?= =?UTF-8?q?=EC=8A=A4=20=EB=8F=84=EC=9E=85?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - 출력(System.out)을 Service에서 제거 → ResultView에서 전담 - 랜덤 이동 로직을 Mover 인터페이스로 분리 (테스트 가능 구조) - carName을 final로 -> Car 클래스 불변성 강화 - 매직 넘버 -> 상수 처리 --- .../controller/RacingCarController.java | 13 +++- src/main/java/racingcar/domain/Car.java | 14 ++-- src/main/java/racingcar/domain/Mover.java | 5 ++ .../java/racingcar/domain/RandomMover.java | 12 ++++ .../racingcar/service/RacingCarService.java | 67 ++++++++++--------- src/main/java/racingcar/view/ResultView.java | 20 +++--- 6 files changed, 85 insertions(+), 46 deletions(-) create mode 100644 src/main/java/racingcar/domain/Mover.java create mode 100644 src/main/java/racingcar/domain/RandomMover.java diff --git a/src/main/java/racingcar/controller/RacingCarController.java b/src/main/java/racingcar/controller/RacingCarController.java index 9409200fd9..c954212a8f 100644 --- a/src/main/java/racingcar/controller/RacingCarController.java +++ b/src/main/java/racingcar/controller/RacingCarController.java @@ -1,15 +1,24 @@ package racingcar.controller; +import racingcar.domain.Car; import racingcar.service.RacingCarService; import racingcar.view.InputView; import racingcar.view.ResultView; +import java.util.List; + public class RacingCarController { private final InputView inputView = new InputView(); private final RacingCarService racingCarService = new RacingCarService(); private final ResultView resultView = new ResultView(); public void run(){ - resultView.printResult(racingCarService.startRace(inputView.readCarNames(), inputView.readRound())); - } + String rawCarNames = inputView.readCarNames(); + int round = inputView.readRound(); + + List> raceHistory = racingCarService.startRace(rawCarNames, round); + resultView.printRaceHistory(raceHistory); + + List winners = racingCarService.getWinners(raceHistory); + resultView.printWinners(winners); } } diff --git a/src/main/java/racingcar/domain/Car.java b/src/main/java/racingcar/domain/Car.java index 34ce695c42..319104be8b 100644 --- a/src/main/java/racingcar/domain/Car.java +++ b/src/main/java/racingcar/domain/Car.java @@ -1,12 +1,16 @@ package racingcar.domain; public class Car { - private String carName; + private final String carName; // carName은 불변이니까 private int position; public Car(String carName) { + this(carName, 0); + } + + public Car(String carName, int position) { this.carName = carName; - this.position = 0; + this.position = position; } public String getCarName() { @@ -17,7 +21,9 @@ public int getPosition() { return position; } - public void move() { - position++; + public void moveIfPossible(Mover mover) { + if (mover.canMove()) { + position++; + } } } diff --git a/src/main/java/racingcar/domain/Mover.java b/src/main/java/racingcar/domain/Mover.java new file mode 100644 index 0000000000..30859cae49 --- /dev/null +++ b/src/main/java/racingcar/domain/Mover.java @@ -0,0 +1,5 @@ +package racingcar.domain; + +public interface Mover { + boolean canMove(); +} diff --git a/src/main/java/racingcar/domain/RandomMover.java b/src/main/java/racingcar/domain/RandomMover.java new file mode 100644 index 0000000000..b40145dcf7 --- /dev/null +++ b/src/main/java/racingcar/domain/RandomMover.java @@ -0,0 +1,12 @@ +package racingcar.domain; + +import camp.nextstep.edu.missionutils.Randoms; + +public class RandomMover implements Mover { + private static final int MOVE_THRESHOLD = 4; + + @Override + public boolean canMove() { + return Randoms.pickNumberInRange(0, 9) >= MOVE_THRESHOLD; + } +} diff --git a/src/main/java/racingcar/service/RacingCarService.java b/src/main/java/racingcar/service/RacingCarService.java index 73b6e6cf40..254d994a62 100644 --- a/src/main/java/racingcar/service/RacingCarService.java +++ b/src/main/java/racingcar/service/RacingCarService.java @@ -17,45 +17,48 @@ WinnersFinder */ -import racingcar.domain.Car; -import racingcar.domain.CarNameValidator; -import racingcar.domain.RoundValidator; +import racingcar.domain.*; import camp.nextstep.edu.missionutils.Randoms; -import racingcar.domain.WinnerCalculator; +import java.util.ArrayList; import java.util.List; public class RacingCarService { - public static final String PLAY_MSG = "실행 결과"; - - public static final CarNameValidator carNameVerifier = new CarNameValidator(); - public static final RoundValidator roundVerifier = new RoundValidator(); - public static final WinnerCalculator winnersFinder = new WinnerCalculator(); - - public List startRace(String rawCarNames, int rawRound) { - // CarNameVerifier - List carList = carNameVerifier.createCarList(rawCarNames); - - // RoundVerifier - int round = roundVerifier.getRound(rawRound); - - System.out.println(PLAY_MSG); - // Racing -> RandomMover - for(int i=0; i= 4){ - currentCar.move(); - } - System.out.print(currentCar.getCarName()+" : "); - - for(int j=0; j> startRace(String rawCarNames, int rawRound) { + List carList = carNameValidator.createCarList(rawCarNames); + int round = roundValidator.validateRound(rawRound); + + List> raceHistory = new ArrayList<>(); + + for (int i = 0; i < round; i++) { + for (Car car : carList) { + car.moveIfPossible(mover); } - System.out.println(); + // 현재 라운드 snapshot 저장 + raceHistory.add(cloneCars(carList)); } - return winnersFinder.findWinners(carList); + return raceHistory; + } + + public List getWinners(List> raceHistory) { + List lastRound = raceHistory.get(raceHistory.size() - 1); + return winnerCalculator.calculate(lastRound); + } + + private List cloneCars(List cars) { + List snapshot = new ArrayList<>(); + for (Car car : cars) { + snapshot.add(new Car(car.getCarName(), car.getPosition())); + } + return snapshot; } } diff --git a/src/main/java/racingcar/view/ResultView.java b/src/main/java/racingcar/view/ResultView.java index 52e61176d7..6a8024a7b3 100644 --- a/src/main/java/racingcar/view/ResultView.java +++ b/src/main/java/racingcar/view/ResultView.java @@ -7,15 +7,19 @@ public class ResultView { private static final String RESULT_MSG = "최종 우승자 : "; - public void printResult(List winners) { - StringBuilder resultString = new StringBuilder(RESULT_MSG); - - // 람다로 써보기 - for(int i=0; i> raceHistory) { + System.out.println("실행 결과"); + for (List round : raceHistory) { + for (Car car : round) { + System.out.println(car.getCarName() + " : " + "-".repeat(car.getPosition())); + } + System.out.println(); } - resultString.append(winners.get(winners.size() - 1).getCarName()); + } - System.out.println(resultString); + public void printWinners(List winners) { + String names = String.join(", ", + winners.stream().map(Car::getCarName).toList()); + System.out.println(RESULT_MSG + names); } } From becb605a34134b97d3fb3748cad3ece467c27fff Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sat, 27 Sep 2025 23:05:20 +0900 Subject: [PATCH 14/15] Update README.md --- README.md | 103 ++++++++++++++++++++++++++++++++++++++++++------------ 1 file changed, 80 insertions(+), 23 deletions(-) diff --git a/README.md b/README.md index fa8bcacb60..2312706de6 100644 --- a/README.md +++ b/README.md @@ -1,24 +1,81 @@ -# java-racingcar-precourse 기능 목록 - -## InputView: 입력 받기 - -## **RacingCarService: winners 리스트 반환** - -- 입력 검증(CarNameVerifier, RoundVerifier) - - CarNameVerifier: - - 예외: strip → 이름.length() > 5 - - 예외: isblank - - RoundVerifier: - - 예외: 숫자가 아닌 값이 들어올 때 - - ~~예외: 횟수가 int 범위를 벗어날 때~~ 상식적으로 게임 라운드가 int범위를 넘기지 않을 거라고 판단. - - 예외: 음수일 때 -- Car 생성 -- ‘실행 결과' 출력 - 이거 Racing에 들어있으면 좋겠는데 -- **Racing - 여기도 좀 리팩토링 하고 싶은데** - - round만큼 반복 - - RandomMover - - 라운드 별 실행 결과 출력 -- WinnersFinder - -## ResultView +## 1. 구현 기능 목록 +### 1. 입력 기능 + +- [x] 자동차 이름 입력받기 + - 사용자로부터 쉼표(,)로 구분된 자동차 이름 문자열 입력받기 + - 입력 메시지: "경주할 자동차 이름을 입력하세요.(이름은 쉼표(,) 기준으로 구분)" +- [x] 시도 횟수 입력받기 + - 사용자로부터 경주 진행 횟수 입력받기 + - 입력 메시지: "시도할 회수는 몇회인가요?" + +### 2. 입력 검증 기능 + +- [x] 자동차 이름 검증하기 + - 이름이 5자 이하인지 검증 + - 공백 또는 빈 문자열 검증 + - 검증 실패 시 `IllegalArgumentException` 발생 +- [x] 시도 횟수 검증하기 + - 숫자 형식인지 검증 (NumberFormatException 처리) + - 음수가 아닌지 검증 + - 검증 실패 시 `IllegalArgumentException` 발생 + +### 3. 자동차 도메인 기능 + +- [x] 자동차 객체 생성하기 + - 자동차 이름과 초기 위치(0) 설정 + - 자동차 이름은 불변값으로 관리 +- [x] 자동차 이동 기능 구현하기 + - 0~9 사이 랜덤 값 생성 + - 랜덤 값이 4 이상일 때 전진 (위치 +1) + - 4 미만일 때는 정지 (위치 변화 없음) + +### 4. 게임 진행 기능 + +- [x] 경주 게임 실행하기 + - 입력받은 횟수만큼 라운드 반복 + - 각 라운드에서 모든 자동차에 대해 이동 판정 + - 라운드별 자동차 상태를 히스토리로 저장 +- [x] 우승자 계산하기 + - 최종 라운드에서 가장 멀리 이동한 자동차 찾기 + - 동일한 최대 거리의 자동차들을 모두 우승자로 선정 + +### 5. 출력 기능 + +- [x] 경주 진행 과정 출력하기 + - "실행 결과" 메시지 출력 + - 각 라운드별로 모든 자동차의 상태 출력 + - 자동차 이름과 이동 거리를 문자로 표현 + - 라운드 간 빈 줄로 구분 +- [x] 최종 우승자 출력하기 + - "최종 우승자 : " 메시지와 함께 우승자 이름 출력 + - 우승자가 여러 명인 경우 쉼표(,)로 구분하여 출력 + +### 6. 전체 애플리케이션 제어 기능 + +- [x] 게임 전체 흐름 제어하기 + - 입력 → 검증 → 게임 실행 → 결과 출력 순서로 진행 + - 예외 발생 시 애플리케이션 종료 + +## 2. 기술적 구현 + +### 객체지향 설계 + +- [x] MVC 패턴 적용 + - Controller: 전체 흐름 제어 + - View: 입력/출력 담당 + - Service: 비즈니스 로직 처리 + - Domain: 핵심 도메인 모델 +- [x] 전략 패턴 적용 + - Mover 인터페이스로 이동 로직 추상화 + - RandomMover로 랜덤 기반 이동 구현 + +### 데이터 관리 + +- [x] 불변 객체 활용 + - 자동차 이름은 생성 후 변경 불가 + - 각 라운드 상태를 스냅샷으로 보존 +- [x] 컬렉션 활용 + - List를 활용한 자동차 목록 관리 + - 2차원 List로 라운드별 히스토리 관리 + From 61efb6e0daa3c33f37c679434fa8ea186c481df8 Mon Sep 17 00:00:00 2001 From: sem_in_github Date: Sun, 28 Sep 2025 09:02:32 +0900 Subject: [PATCH 15/15] =?UTF-8?q?refactor:=20=EC=A3=BC=EC=84=9D=20?= =?UTF-8?q?=EC=A0=9C=EA=B1=B0=20=EB=B0=8F=20=EC=85=80=ED=94=84=20comment?= =?UTF-8?q?=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../controller/RacingCarController.java | 9 +++++---- .../racingcar/domain/CarNameValidator.java | 3 --- .../racingcar/service/RacingCarService.java | 20 ------------------- src/main/java/racingcar/view/InputView.java | 2 +- src/main/java/racingcar/view/ResultView.java | 1 + 5 files changed, 7 insertions(+), 28 deletions(-) diff --git a/src/main/java/racingcar/controller/RacingCarController.java b/src/main/java/racingcar/controller/RacingCarController.java index c954212a8f..b90feca5b4 100644 --- a/src/main/java/racingcar/controller/RacingCarController.java +++ b/src/main/java/racingcar/controller/RacingCarController.java @@ -14,11 +14,12 @@ public class RacingCarController { public void run(){ String rawCarNames = inputView.readCarNames(); - int round = inputView.readRound(); + int rawRound = inputView.readRound(); // 변수명 일관성 - List> raceHistory = racingCarService.startRace(rawCarNames, round); + List> raceHistory = racingCarService.startRace(rawCarNames, rawRound); resultView.printRaceHistory(raceHistory); - List winners = racingCarService.getWinners(raceHistory); - resultView.printWinners(winners); } + List winners = racingCarService.getWinners(raceHistory); // raceHistory 객체라니 진짜 짱이다 + resultView.printWinners(winners); + } } diff --git a/src/main/java/racingcar/domain/CarNameValidator.java b/src/main/java/racingcar/domain/CarNameValidator.java index ad7f6fb8c0..7acd27533b 100644 --- a/src/main/java/racingcar/domain/CarNameValidator.java +++ b/src/main/java/racingcar/domain/CarNameValidator.java @@ -3,7 +3,6 @@ import java.util.ArrayList; import java.util.List; -// TODO: split 기능도 추가됨 -> 클래스명 바꾸거나 분리하기 public class CarNameValidator { public List createCarList(String rawStringOfCarNames) { @@ -14,8 +13,6 @@ public List createCarList(String rawStringOfCarNames) { throw new IllegalArgumentException("[ERROR] 공백은 안 받아요"); } - // CarNameVerifier - // "jenny "거나 " " String[] carNamesArray = rawStringOfCarNames.split(","); for(String carName : carNamesArray) { String trimmed = carName.strip(); diff --git a/src/main/java/racingcar/service/RacingCarService.java b/src/main/java/racingcar/service/RacingCarService.java index 254d994a62..22adb2ee1b 100644 --- a/src/main/java/racingcar/service/RacingCarService.java +++ b/src/main/java/racingcar/service/RacingCarService.java @@ -1,30 +1,10 @@ package racingcar.service; -/* -* 입력 검증(CarNameVerifier, RoundVerifier) -CarNameVerifier: -예외: strip → 이름.length() > 5 -예외: isblank -RoundVerifier: -예외: 숫자가 아닌 값이 들어올 때 -예외: 음수일 때 -Car 생성 -‘실행 결과' 출력 - 이거 Racing에 들어있으면 좋겠는데 -Racing - 여기도 좀 리팩토링 하고 싶은데 -round만큼 반복 -RandomMover -라운드 별 실행 결과 출력 -WinnersFinder -*/ - import racingcar.domain.*; -import camp.nextstep.edu.missionutils.Randoms; - import java.util.ArrayList; import java.util.List; public class RacingCarService { - // public static final String PLAY_MSG = "실행 결과"; public static final CarNameValidator carNameValidator = new CarNameValidator(); public static final RoundValidator roundValidator = new RoundValidator(); diff --git a/src/main/java/racingcar/view/InputView.java b/src/main/java/racingcar/view/InputView.java index 5a09eebb12..f6afad5fbb 100644 --- a/src/main/java/racingcar/view/InputView.java +++ b/src/main/java/racingcar/view/InputView.java @@ -7,7 +7,7 @@ public class InputView { private static final String ROUND_INPUT_MSG = "시도할 회수는 몇회인가요?"; public String readCarNames() { - System.out.println(CARNAMES_INPUT_MSG); + System.out.println(CARNAMES_INPUT_MSG); // REQUEST MSG라는 말이 더 맘에 들어 return Console.readLine().strip(); } diff --git a/src/main/java/racingcar/view/ResultView.java b/src/main/java/racingcar/view/ResultView.java index 6a8024a7b3..50b5589300 100644 --- a/src/main/java/racingcar/view/ResultView.java +++ b/src/main/java/racingcar/view/ResultView.java @@ -7,6 +7,7 @@ public class ResultView { private static final String RESULT_MSG = "최종 우승자 : "; + // stringbuilder 쓰면 시간 개선할 수 있을텐데 public void printRaceHistory(List> raceHistory) { System.out.println("실행 결과"); for (List round : raceHistory) {