문제
정보문화진흥원 정보 영재 동아리에서 동아리 활동을 하던 영수와 민혁이는 쉬는 시간을 틈타 숫자야구 게임을 하기로 했다.
- 영수는 1에서 9까지의 서로 다른 숫자 세 개로 구성된 세 자릿수를 마음속으로 생각한다. (예: 324)
- 민혁이는 1에서 9까지의 서로 다른 숫자 세 개로 구성된 세 자리 수를 영수에게 묻는다. (예: 123)
- 민혁이가 말한 세 자리 수에자릿수에 있는 숫자들 중 하나가 영수의 세 자리 수의 동일한 자리에 위치하면 스트라이크 한 번으로 센다. 숫자가 영수의 세 자릿수에 있긴 하나 다른 자리에 위치하면 볼 한 번으로 센다.
예) 영수가 324를 갖고 있으면
- 429는 1 스트라이크 1 볼이다.
- 241은 0 스트라이크 2 볼이다.
- 924는 2 스트라이크 0 볼이다.
- 영수는 민혁이가 말한 수가 몇 스트라이크 몇 볼인지를 답해준다.
- 민혁이가 영수의 세 자리 수를 정확하게 맞추어 3 스트라이크가 되면 게임이 끝난다. 아니라면 민혁이는 새로운 수를 생각해 다시 영수에게 묻는다.
현재 민혁이와 영수는 게임을 하고 있는 도중에 있다. 민혁이가 영수에게 어떤 수들을 물어보았는지, 그리고 각각의 물음에 영수가 어떤 대답을 했는지가 입력으로 주어진다. 이 입력을 바탕으로 여러분은 영수가 생각하고 있을 가능성이 있는 수가 총 몇 개인지를 알아맞혀야 한다.
아래와 같은 경우를 생각해보자.
- 민혁: 123
- 영수: 1 스트라이크 1 볼.
- 민혁: 356
- 영수: 1 스트라이크 0 볼.
- 민혁: 327
- 영수: 2 스트라이크 0 볼.
- 민혁: 489
- 영수: 0 스트라이크 1 볼.
이때 가능한 답은 324와 328, 이렇게 두 가지이다.
영수는 동아리의 규율을 잘 따르는 착한 아이라 민혁이의 물음에 곧이곧대로 정직하게 답한다. 그러므로 영수의 답들에는 모순이 없다.
민혁이의 물음들과 각각의 물음에 대한 영수의 답이 입력으로 주어질 때 영수가 생각하고 있을 가능성이 있는 답의 총개수를 출력하는 프로그램을 작성하시오.
입력
첫째 줄에는 민혁이가 영수에게 몇 번이나 질문을 했는지를 나타내는 1 이상 100 이하의 자연수 N이 주어진다. 이어지는 N개의 줄에는 각 줄마다 민혁이가 질문한 세 자리 수와 영수가 답한 스트라이크 개수를 나타내는 정수와 볼의 개수를 나타내는 정수, 이렇게 총 세 개의 정수가 빈칸을 사이에 두고 주어진다.
출력
첫 줄에 영수가 생각하고 있을 가능성이 있는 답의 총 개수를 출력한다.
테스트 케이스
입력 1
3
123 1 0
456 1 0
789 1 0
출력 1
6
입력 2
1
123 1 0
출력 2
90
입력 3
1
123 2 1
출력 3
0
접근
중요한 것은 0이 들어가지 않는다는 것과 중복된 수가 없다는 것입니다.
결국 123부터 987까지 수를 골면서 중복된 수가 나오면 빼고, 0이 들어가는 수는 빼야 합니다.
그 후, 입력받은 수들과 비교하여 strike와 볼의 수가 같으면 count 해줍니다.
예를 들면 324이란 수가 있습니다.
근데
123 1 1
356 1 0
327 2 0
489 0 1
라는 입력이 들어오면 각각의 케이스를 비교합니다.
324와 123 을 비교하여 자리수 같은 값 1개 숫자만 같은거 1개 strike 1개 ball1개 일치합니다.
324 와 345를 비교하여 자릿수 같은 값 1개 숫자만 같은 거 0 개 strike1개 ball0개 일치합니다.
...
...
4가지 입력 strike ball이 모두 일치하면 count 합니다.
만약 456이었다면
123과 strike수와 ball수가 다르므로 일치하지 않게 됩니다.
기본적인 로직은 이렇습니다.
코드
import java.awt.desktop.SystemEventListener;
import java.io.*;
import java.math.*;
import java.util.*;
public class Main {
/*
* 2503 problem
*/
public static void main(String[] args) throws NumberFormatException, IOException {
// TODO Auto-generated method stub
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
int num = Integer.parseInt(br.readLine());
int arr[] = new int[num];
int strike[] = new int[num];
int ball[] = new int[num];
int count = 0;
for(int i=0; i<num; i++) {
StringTokenizer st = new StringTokenizer(br.readLine());
arr[i] = Integer.parseInt(st.nextToken());
strike[i] = Integer.parseInt(st.nextToken());
ball[i] = Integer.parseInt(st.nextToken());
}
for(int i=123; i<=987; i++) {
int strike_temp =0;
int ball_temp = 0;
int check = 0;
if(i/100 == i/10%10)continue;
else if(i/10%10 == i%10) continue;
else if(i/100 == i%10) continue;
if(i/10%10 == 0) continue;
if(i%10 == 0) continue;
for(int j=0; j<strike.length; j++) {
strike_temp = 0;
ball_temp = 0;
if(arr[j]/100 == i/100) {
strike_temp++;
}
else {
if(arr[j]/10%10 ==i/100) {
ball_temp++;
}
else if(arr[j]%10 == i/100) {
ball_temp++;
}
}
if(arr[j]/10%10== i/10%10) {
strike_temp++;
}
else {
if(arr[j]/100 ==i/10%10) {
ball_temp++;
}
else if(arr[j]%10 == i/10%10) {
ball_temp++;
}
}
if(arr[j]%10 == i%10) {
strike_temp++;
}
else {
if(arr[j]/100 ==i%10) {
ball_temp++;
}
else if(arr[j]/10%10 == i%10) {
ball_temp++;
}
}
if(strike[j]!=strike_temp || ball[j]!=ball_temp) {
break;
}
check++;
if(check == num) {
count++;
}
}
}
bw.write(String.valueOf(count));
bw.flush();
br.close();
bw.close();
}
}
주의
세 자리 수가 들어왔을 때, i/100은 백의 자리, i/10%10는 십의 자리, i%10은 일의 자리입니다.
'공부 정리 > 백준' 카테고리의 다른 글
[백준] 자바 1764 듣보잡 (0) | 2021.10.11 |
---|---|
[백준] 자바 1676 팩토리얼 0의 개수 (0) | 2021.10.08 |
[백준] 자바 15829 Hashing (0) | 2021.10.06 |
[백준] 자바 2108 통계학 (0) | 2021.10.05 |
[백준] 자바 11866 요세푸스 문제 0 (0) | 2021.10.04 |
댓글