[필수개념] 조합 관련 문의
488
작성한 질문수 6
안녕하세요.
조합 코드 관련하여 문의드립니다.
아래 코드대로 출력했을 때
0 1 2
0 1 3
0 1 4
0 2 3
0 2 4
0 3 4
1 2 3
1 2 4
1 3 4
2 3 4
이와 같이 나옵니다.
combi 함수에서 for문을
for(int i=start+1; i<=n; i++) 로 변경하면 '5'도 출력되는데 .. 변경하는 게 맞을까요?
답변 부탁드려요..
#include <bits/stdc++.h>
using namespace std;
int n=5, k=3, a[5]={1,2,3,4,5};
void print(vector<int> b){
for(int i:b)cout << i << " ";
cout << '\n';
}
void combi(int start, vector<int> b){
if(b.size()==k){
print(b);
return ;
}
for(int i=start+1; i<n;i++){
b.push_back(i);
combi(i,b);
b.pop_back();
}
return ;
}
int main (){
vector<int> b;
combi(-1,b);
return 0;
}
답변 1
0
안녕하세요 9201님 ㅎㅎ
void combi(int start, vector<int> b){
if(b.size() == k){
print(b);
return;
}
for(int i = start + 1; i < n; i++){
b.push_back(i);
combi(i, b);
b.pop_back();
}
return;
} 이부분을
void combi(int start, vector<int> b){
if(b.size() == k){
print(b);
return;
}
for(int i = start + 1; i <= n; i++){
b.push_back(i);
combi(i, b);
b.pop_back();
}
return;
} 앞의 코드처럼 바꿨다는 말씀이시죠?
안됩니다.
a[5] = {1, 2, 3, 4, 5};이 코드의 이미는 5의 크기를 가지는 배열을 정의한 것입니다.
0, 1, 2, 3, 4 라는 인덱스로 참조가 가능하죠. 근데 여기서
<= n을 하게 되면
5라는 인덱스를 참조할거야!! 하면서 5라는 인덱스를 집어넣게 되버리겠죠?
한번 구동시켜볼까요?
#include <bits/stdc++.h>
using namespace std;
int n = 5, k = 3, a[5] = {1, 2, 3, 4, 5};
void print(vector<int> b){
for(int i : b)cout << i << " ";
cout << '\n';
}
void combi(int start, vector<int> b){
if(b.size() == k){
print(b);
return;
}
for(int i = start + 1; i <= n; i++){
b.push_back(i);
combi(i, b);
b.pop_back();
}
return;
}
int main() {
vector<int> b;
combi(-1, b);
return 0;
}
이를 구동시키면
0 1 2
0 1 3
0 1 4
0 1 5
0 2 3
0 2 4
0 2 5
0 3 4
0 3 5
0 4 5
1 2 3
1 2 4
1 2 5
1 3 4
1 3 5
1 4 5
2 3 4
2 3 5
2 4 5
3 4 5다음과 같이 5라는 인덱스가 뽑혀져 나옵니다.
우리는 인덱스를 뽑는 거지, 값을 뽑는 게 아닙니다. 0번째, 1번쨰, 2번째 인덱스를 추출하는것에 집중해주세요.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제가 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
5-B
0
15
2
4 - A
0
33
2
코딩살구클럽 입장이 안됩니다
0
82
2
4-F 경우의 수 질문입니다.
0
35
2
코딩살구클럽 가입이 안됩니다.
0
85
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
63
1
교안 158페이지 문의드립니다
0
46
2
코딩살구클럽 관련 건의사항
0
119
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
45
1
진행 방법 질문드립니다!
0
83
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
64
2
2주차 개념#12 트리 순회
0
33
2
백준사이트가 종료된다고 합니다.
0
318
2
백준 서비스 종료
9
953
1
sk 하이닉스 코테 대비
0
388
2
3-G 최댓값 질문
0
54
1
모듈러 연산 값이 10이 아닌 경우도 있지 않나요?
0
84
2
3-I 코드 질문드립니다.
0
66
2
3-N 질문 있습니다.
0
68
2
학습방법
0
105
2
4-H 질문 있습니다 (코드 리뷰)
0
69
2
코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.
0
186
2
2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.
0
74
2
2주차 개념 #4-2. 인접행렬 질문있습니다.
0
66
2





