pp 역 추적 알고리즘 컴 퓨 팅 조합 총화 인 스 턴 스 코드
candidates 의 모든 숫자 는 조합 에서 한 번 만 사용 할 수 있 습 니 다.
설명 하 다.
모든 숫자(목표 수 포함)는 정수 이다.해 집 은 중복 되 는 조합 을 포함 할 수 없습니다.
실례
입력:
candidates = [10,1,2,7,6,1,5], target = 8,
구 해 집합:
[
[1, 7],
[1, 2, 5],
[2, 6],
[1, 1, 6]]
문제 풀이 의 사고 방향.
역 추적 알고리즘 단 멸 배열/조합/부분 집합 문 제 를 직접 참고 하 다.
코드
class Solution {
/** * @param Integer[] $candidates * @param Integer $target * @return Integer[][] */
public $res = [];
function combinationSum2($candidates, $target) {
sort($candidates); //
$this->dfs([], $candidates, $target, 0);
return $this->res;
}
function dfs($array, $candidates, $target, $start) {
if ($target < 0) return;
if ($target === 0) {
$this->res[] = $array;
return;
}
$count = count($candidates);
for ($i = $start; $i < $count; $i++) {
if ($i !== $start && $candidates[$i] === $candidates[$i - 1]) continue;
$array[] = $candidates[$i];
$this->dfs($array, $candidates, $target - $candidates[$i], $i + 1);// , +1
array_pop($array);
}}
인 스 턴 스 확장:
<?php
/*
* k = 2x + y + 1/2z
* 0 <= x <= 1/2k
* 0 <= y <= k
* 0 <= z < = 2k
* x,y,z 2k
*/
$daMi = 100;
$result = array();
function isOk($t,$daMi,$result)
{/*{{{*/
$total = 0;
$hash = array();
$hash[1] = 2;
$hash[2] = 1;
$hash[3] = 0.5;
for($i=1;$i<=$t;$i++)
{
$total += $result[$i] * $hash[$i];
}
if( $total <= $daMi)
{
return true;
}
return false;
}/*}}}*/
function backtrack($t,$daMi,$result)
{/*{{{*/
//
if($t > 3)
{
//
if($daMi == (2 * $result[1] + $result[2] + 0.5 * $result[3]))
{
echo " , :${daMi}, :$result[1], : $result[2], :$result[3]
";
}
return;
}
for($i = 0;$i <= 2 * $daMi;$i++)
{
$result[$t] = $i;
//
if(isOk($t,$daMi,$result))
{
backtrack($t+1,$daMi,$result);
}
$result[$t] = 0;
}
}/*}}}*/
backtrack(1,$daMi,$result);
?>
phop 역 추적 알고리즘 컴 퓨 팅 조합 총화 의 인 스 턴 스 코드 에 관 한 이 글 은 여기까지 소개 되 었 습 니 다.phop 역 추적 알고리즘 컴 퓨 팅 조합 총화 에 관 한 더 많은 방법 내용 은 우리 의 이전 글 을 검색 하거나 아래 의 관련 글 을 계속 조회 하 시기 바 랍 니 다.앞으로 저 를 많이 지지 해 주세요!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Laravel - 변환된 유효성 검사 규칙으로 API 요청 제공동적 콘텐츠를 위해 API를 통해 Laravel CMS에 연결하는 모바일 앱(또는 웹사이트) 구축을 고려하십시오. 이제 앱은 CMS에서 번역된 콘텐츠를 받을 것으로 예상되는 다국어 앱이 될 수 있습니다. 일반적으로 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.