ZOJ1101的强化版,求序列中多个数之和是否存在于序列之中,并排序输出.
由于题目要求按算式"字符串"顺序输出,在DFS过程中以数字个数为DFS的深度限制.
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
Code
1
#include <iostream>
2
#include <vector>
3
#include <algorithm>
4
using namespace std;
5data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
6
vector<int> datas;
7
vector<int> result;
8
bool isFind;
9data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
10
// int sort function
11
int IntCompare(const void * i1, const void * i2)
12data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
13
return (*(const int*)i1) > (*(const int*)i2);
14
}
15data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
16
// start is the search start index
17
// dest_deep is the search destination depth
18
// current_deep is the search of current depth
19
// current_sum is the sum of current searchable numbers
20
void DFS(int start, int dest_deep, int current_deep, int current_sum)
21data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
22
// if reach the dstination depth
23
if(current_deep == dest_deep)
24data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
25
// if we have the sum in the list
26
if(binary_search(datas.begin(), datas.end(), current_sum))
27data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
28
// output it
29
for(int i = 0; i < dest_deep - 1; ++i)
30data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
31
cout << result[i] << "+";
32
}
33
cout << result[dest_deep - 1] << "=" << current_sum << endl;
34
isFind = true;
35
}
36
}
37
// otherwise if we haven't reach the destination depth, go on searching
38
else
39data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
40
int size = datas.size();
41
// search from start to avoid duplicate result such as 1+2=3 and 2+1=3
42
for(int i = start; i < size; ++i)
43data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
44
// store my search result
45
if(current_deep < result.size())
46data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
47
result[current_deep] = datas[i];
48
}
49
else
50data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
51
result.push_back(datas[i]);
52
}
53data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
54
// if the sum is bigger than the biggest one in the list, break the loop
55
if(current_sum + datas[i] > datas[datas.size() - 1])
56
break;
57
// search next, increase start avoid duplicate, increase depth, re-calculate sum
58
DFS(i + 1, dest_deep, current_deep + 1, current_sum + datas[i]);
59
}
60
}
61
}
62data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
63
int _tmain(int argc, _TCHAR* argv[])
64data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
65
int n;
66
cin >> n;
67
for(int i = 0; i < n; ++i)
68data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
69
int count;
70
cin >> count;
71
int number;
72
for(int j = 0; j < count; ++j)
73data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
74
cin >> number;
75
datas.push_back(number);
76
}
77data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
78
qsort(&datas[0], count, sizeof(int), IntCompare);
79data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
80
isFind = false;
81
for(int i = 2; i < count; ++i)
82data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
83
// i indicate the depth of the search, 2 is the lowest and count-1 is the largest
84
DFS(0, i, 0, 0);
85
}
86
if(!isFind)
87
cout << "Can't find any equations." << endl;
88
cout << endl;
89
datas.clear();
90
}
91
return 0;
92
}
93data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
posted on 2009-03-31 20:54
肖羽思 阅读(2134)
评论(0) 编辑 收藏 引用 所属分类:
ZOJ