귀속과 배열 조합
비반복 배열 조합
방법 1:
사상: 제 index 개 원소에 대해 순서대로 후속 모든 원소 index+i를 보고 그를 조합(시도는 진일보한 귀속을 하는 것이다)List> re=new ArrayList>();
public void combine(int index,int k,int n,List temp){
if(n<0) return;
if(k==0&&n==0){
re.add(new ArrayList<>(temp));
return;
}
if(k<=0) return;
for(int i=index;i<10;i++){
temp.add(i);
combine(i+1,k-1, n-i,temp);
temp.remove(temp.size()-1);
}
return;
}
public List> combinationSum3(int k, int n) {
List temp=new ArrayList<>();
combine(1,k, n, temp);
return re;
}
방법 2:
사상: 제 index 개 원소에 대해 이 원소를 넣거나 넣지 않는 두 가지 상황만 보고 다음 원소 index+1로 귀속한다.이 방법은remove 요소가 필요합니다.List> re=new ArrayList>();
public void combine(int index,int k,int n,List temp){
if(n<0) return;
if(k==0&&n==0){
re.add(new ArrayList<>(temp));
return;
}
if(index>9) return;
if(k<=0) return;
temp.add(index);
combine(index+1,k-1, n-index,temp);
temp.remove(temp.size()-1);
combine(index+1,k, n,temp);
return;
}
public List> combinationSum3(int k, int n) {
List temp=new ArrayList<>();
combine(1,k, n, temp);
return re;
}
반복 배열 조합 있음
사실 앞의 비중복 배열 조합을 대조하여 중복이 있는 것을 쓰는 것은 이미 매우 간단하다
방법 1:
변경된 곳:combine(i+1,k-1,n-i,temp)가combine(i,k-1,n-i,temp)로 바뀌었습니다. 왜냐하면 i의 원소가 중복 사용될 수 있기 때문입니다.List> re=new ArrayList>();
public void combine(int index,int k,int n,List temp){
if(n<0) return;
if(k==0&&n==0){
re.add(new ArrayList<>(temp));
return;
}
if(k<=0) return;
for(int i=index;i<10;i++){
temp.add(i);
combine(i,k-1, n-i,temp);
temp.remove(temp.size()-1);
}
return;
}
public List> combinationSum3(int k, int n) {
List temp=new ArrayList<>();
combine(1,k, n, temp);
return re;
}
방법 2:
변경된 곳:combine(index+1,k-1,n-index,temp)가combine(index,k-1,n-index,temp)로 변한다.인덱스 요소가 중복 사용될 수 있기 때문에List> re=new ArrayList>();
public void combine(int index,int k,int n,List temp){
if(n<0) return;
if(k==0&&n==0){
re.add(new ArrayList<>(temp));
return;
}
if(index>9) return;
if(k<=0) return;
temp.add(index);
combine(index,k-1, n-index,temp);
temp.remove(temp.size()-1);
combine(index+1,k, n,temp);
return;
}
public List> combinationSum3(int k, int n) {
List temp=new ArrayList<>();
combine(1,k, n, temp);
return re;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSON
JSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다.
그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다.
저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.
List> re=new ArrayList>();
public void combine(int index,int k,int n,List temp){
if(n<0) return;
if(k==0&&n==0){
re.add(new ArrayList<>(temp));
return;
}
if(k<=0) return;
for(int i=index;i<10;i++){
temp.add(i);
combine(i+1,k-1, n-i,temp);
temp.remove(temp.size()-1);
}
return;
}
public List> combinationSum3(int k, int n) {
List temp=new ArrayList<>();
combine(1,k, n, temp);
return re;
}
List> re=new ArrayList>();
public void combine(int index,int k,int n,List temp){
if(n<0) return;
if(k==0&&n==0){
re.add(new ArrayList<>(temp));
return;
}
if(index>9) return;
if(k<=0) return;
temp.add(index);
combine(index+1,k-1, n-index,temp);
temp.remove(temp.size()-1);
combine(index+1,k, n,temp);
return;
}
public List> combinationSum3(int k, int n) {
List temp=new ArrayList<>();
combine(1,k, n, temp);
return re;
}
사실 앞의 비중복 배열 조합을 대조하여 중복이 있는 것을 쓰는 것은 이미 매우 간단하다
방법 1:
변경된 곳:combine(i+1,k-1,n-i,temp)가combine(i,k-1,n-i,temp)로 바뀌었습니다. 왜냐하면 i의 원소가 중복 사용될 수 있기 때문입니다.
List> re=new ArrayList>();
public void combine(int index,int k,int n,List temp){
if(n<0) return;
if(k==0&&n==0){
re.add(new ArrayList<>(temp));
return;
}
if(k<=0) return;
for(int i=index;i<10;i++){
temp.add(i);
combine(i,k-1, n-i,temp);
temp.remove(temp.size()-1);
}
return;
}
public List> combinationSum3(int k, int n) {
List temp=new ArrayList<>();
combine(1,k, n, temp);
return re;
}
방법 2:
변경된 곳:combine(index+1,k-1,n-index,temp)가combine(index,k-1,n-index,temp)로 변한다.인덱스 요소가 중복 사용될 수 있기 때문에
List> re=new ArrayList>();
public void combine(int index,int k,int n,List temp){
if(n<0) return;
if(k==0&&n==0){
re.add(new ArrayList<>(temp));
return;
}
if(index>9) return;
if(k<=0) return;
temp.add(index);
combine(index,k-1, n-index,temp);
temp.remove(temp.size()-1);
combine(index+1,k, n,temp);
return;
}
public List> combinationSum3(int k, int n) {
List temp=new ArrayList<>();
combine(1,k, n, temp);
return re;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.