자료구조 Ds\Set::reduce

(PECL ds >= 1.0.0)

Ds\Set::reduce — 콜백 함수를 사용하여 집합을 단일 값으로 줄입니다.


설명

public Ds\Set::reduce(callable $callback, mixed $initial = ?): mixed

콜백 함수를 사용하여 집합을 단일 값으로 줄입니다.


매개변수

callback

callback(mixed $carry, mixed $value): mixed

carry
이전 콜백의 반환 값 또는 첫 번째 반복인 경우 initial입니다.
value
현재 반복의 값입니다.
initial
캐리 값의 초기 값입니다. null일 수 있습니다.

반환 값

최종 콜백의 반환 값입니다.


Examples

예제 #1 초기 값이 있는 Ds\Set::reduce() 예제

                  
<?php
$set = new \Ds\Set([1, 2, 3]);

$callback = function($carry, $value) {
    return $carry * $value;
};

var_dump($set->reduce($callback, 5));

// Iterations:
//
// $carry = $initial = 5
//
// $carry = $carry * 1 =  5
// $carry = $carry * 2 = 10
// $carry = $carry * 3 = 30
?>
                  
                

위의 예는 다음과 유사한 결과를 출력합니다.

int(30)
                

예제 #2 초기 값이 없는 Ds\Set::reduce() 예제

                  
<?php
$set = new \Ds\Set([1, 2, 3]);

var_dump($set->reduce(function($carry, $value) {
    return $carry + $value + 5;
}));

// Iterations:
//
// $carry = $initial = null
//
// $carry = $carry + 1 + 5 =  6
// $carry = $carry + 2 + 5 = 13
// $carry = $carry + 3 + 5 = 21
?>
                  
                

위의 예는 다음과 유사한 결과를 출력합니다.

int(21)