반응형

https://www.acmicpc.net/problem/7490

 

7490번: 0 만들기

각 테스트 케이스에 대해 ASCII 순서에 따라 결과가 0이 되는 모든 수식을 출력한다. 각 테스트 케이스의 결과는 한 줄을 띄워 구분한다.

www.acmicpc.net

 

 

[ 문제풀이 ]

 

1. 백트래킹을 이용해 실시간으로 계산값들을 저장하고, 각 인덱스에 저장되어 있는 부호가 무엇인지 저장합니다.

 

2. 만약 계산값이 0이라면 vector<stirng> ans에 숫자와 부호를 push합니다.

 

3. ans를 오름차순으로 정렬하고, 출력합니다.

 

[ 소스코드 ]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include<iostream>
#include<vector>
#include<string>
#include<algorithm>
 
using namespace std;
 
int N;
int ret = 0;
char box[10];
vector<string> ans;
 
void dfs(int level, int num, int idx)
{
    if (level == N + 1) {
        if (num != 0) {
            if (box[idx] == '-') {
                ret -= num;
            }
            else {
                ret += num;
            }
        }
        if (ret == 0) {
            string temp;
            for (int i = 1; i <= N; i++) {
                temp += '0' + i;
                temp += box[i];
            }
            ans.push_back(temp);
        }
        if (num != 0) {
            if (box[idx] == '-') {
                ret += num;
            }
            else {
                ret -= num;
            }
        }
        return;
    }
 
    num = num * 10 + level;
 
    if (N != level) {
        if (box[idx] == '-') {
            ret -= num;
            box[level] = '+';
            dfs(level + 10, level);
            box[level] = '-';
            dfs(level + 10, level);
            ret += num;
            box[level] = 0;
        }
        else {
            ret += num;
            box[level] = '+';
            dfs(level + 10, level);
            box[level] = '-';
            dfs(level + 10, level);
            ret -= num;
            box[level] = 0;
        }
    }
 
    box[level] = ' ';
    dfs(level + 1, num, idx);
    box[level] = 0;
 
    return;
}
 
int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);
 
    int T;
    cin >> T;
 
    for (int t = 0; t < T; t++) {
        ans.clear();
        cin >> N;
 
        dfs(1,0,0);
 
        sort(ans.begin(), ans.end());
 
        for (auto& next : ans) {
            cout << next << '\n';
        }
 
        cout << '\n';
    }
}
cs

 

반응형

+ Recent posts