반응형
문제링크:https://www.acmicpc.net/problem/2503
모든 경우를 고려해주며 결과값을 도출하는 브루트포스 문제였습니다.
숫자의 범위가 적기 때문에 어려운 점은 없는 문제였습니다.
1) 100~999까지의 수를 반복하며 확인
2) 이때 0을 포함, 혹은 같은 자릿수를 가지는 수는 제외
3) 같은 자릿수를 가지면 strike값을 올리고 다른 자리에 해당 값이 있다면 ball값을 올려줍니다.
4) 조건을 만족하는 수가 있다면 결과값을 +1씩 올려줍니다.
2번조건을 간과해서 틀릴 수 있습니다. 문제조건을 한번더 확인하는 습관을 가져야겠습니다.
직접문제를 풀어보세요! :0 화이팅
#include <iostream>
#include <algorithm>
using namespace std;
int n = 0, result = 0;
int arr[100][3] = { 0 };
int arr2[9] = { 0 };
int main() {
cin >> n;
for (int i = 0; i < n; i++) {
cin >> arr[i][0] >> arr[i][1] >> arr[i][2];
}
for (int i = 100; i <= 999; i++) {
if (i % 10 == 0) continue; //0 안들어가게
if ((i / 10) % 10 == 0) continue;
if (i / 100 == (i / 10) % 10) continue;
if (i / 100 == i % 10) continue;
if (i % 10 == (i / 10) % 10) continue;
bool jud = true;
for (int j = 0; j < n; j++) {
for (int k = 1; k <= 9; k++) arr2[k] = 0;
bool first = false, second = false, third = false;
int strike = 0, ball = 0;
int num = i;
if (num / 100 == arr[j][0] / 100) strike++,first=true;
arr2[arr[j][0] / 100]++;
if ((num / 10) %10 == (arr[j][0] / 10)%10) strike++,second=true;
arr2[(arr[j][0] / 10) % 10]++;
if (num % 10 == arr[j][0] % 10) strike++,third=true;
arr2[arr[j][0] % 10]++;
if (!first&&arr2[num / 100]) ball++;
if (!second&&arr2[(num / 10) % 10]) ball++;
if (!third&&arr2[num % 10]) ball++;
if (strike != arr[j][1] || ball != arr[j][2]) {
jud = false;
break;
}
}
if (jud == true) {
result++;
}
}
cout << result << endl;
return 0;
}
반응형
'알고리즘 > 브루트포스' 카테고리의 다른 글
[백준] 1038-감소하는 수(C++) (0) | 2020.06.30 |
---|---|
[백준] 11502-세 개의 소수 문제(C++) (0) | 2020.03.31 |
[백준] 1251-단어 나누기(C++) (0) | 2020.03.09 |
[백준] 1051-숫자 정사각형(C++) (0) | 2020.03.09 |
[백준] 2966-찍기(C++) (0) | 2020.03.09 |