알고리즘/SW Expert Academy
[SWEA] 8275 햄스터
세진짱
2020. 3. 4. 15:11
입력받는 숫자들을 보면 엄청 작다
완탐으로 정말 다 찾아보면 된다
답이 여러개라면 숫자가 많은것 중에 사전순으로 앞에오는 것을 출력해야한다
따라서 각 자리마자 0~x까지 넣어보면서 햄스터 수를 만족하고
현재 답보다 합이 크다면 계속 바꿔주면 된다!
소스코드
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
|
#include <bits/stdc++.h>
using namespace std;
#define ll long long
int t,n,x,m;
pair<pair<int,int>,int> arr[11];
int maxcnt;
int ans[11];
void solve(int pos,int sum,vector<int>& vt){
if(pos==n){
if(sum>maxcnt){
for(int i=0;i<m;i++){
int cnt = arr[i].second;
int tempcnt=0;
for(int j=l;j<=r;j++) tempcnt+=vt[j];
if(tempcnt!=cnt) return;
}
for(int i=0;i<n;i++) ans[i]=vt[i];
maxcnt=sum;
}
return;
}
for(int i=0;i<=x;i++){
vt[pos]=i;
solve(pos+1,sum+i,vt);
}
}
int main(){
scanf(" %d",&t);
for(int tc=1;tc<=t;tc++){
maxcnt=-1;
scanf("%d %d %d",&n,&x,&m);
for(int i=0;i<m;i++){
int l,r,q; scanf(" %d %d %d",&l,&r,&q);
arr[i]= {{l-1,r-1},q};
}
vector<int>vt(n);
solve(0,0,vt);
printf("#%d ",tc);
if(maxcnt==-1) printf("-1");
else for(int i=0;i<n;i++) printf("%d ",ans[i]);
puts("");
}
}
|