🛠️ 처음부터 만드는 Partition — 배열을 조건에 따라 2개로 나누기
언제 쓸까?
배열을 참/거짓으로 분류해야 할 때가 많습니다.
```typescript
// 유효한 이메일과 잘못된 이메일 분류
const emails = ['user@test.com', 'invalid', 'admin@app.com', '???'];
const [valid, invalid] = partition(emails, (email) => email.includes('@'));
console.log(valid); // ['user@test.com', 'admin@app.com']
console.log(invalid); // ['invalid', '???']
```
Filter로 두 번 돌리는 것보다 효율적입니다.
구현
```typescript
const partition =(
arr: T[],
predicate: (item: T, index: number) => boolean
): [T[], T[]] => {
return arr.reduce(
([pass, fail], item, index) =>
predicate(item, index)
? [[...pass, item], fail]
: [pass, [...fail, item]],
[[], []] as [T[], T[]]
);
};
```
실전 예제
```typescript
// API 응답 성공/실패 분류
const responses = [200, 404, 200, 500, 201];
const [success, errors] = partition(
responses,
(status) => status >= 200 && status < 300
);
// 유효성 검사
const users = [
{ name: 'Alice', age: 25 },
{ name: 'Bob', age: 17 },
{ name: 'Charlie', age: 30 },
];
const [adults, minors] = partition(users, (u) => u.age >= 18);
```
배열을 한 번만 순회하면서 두 그룹을 동시에 얻습니다.
배열을 참/거짓으로 분류해야 할 때가 많습니다.
```typescript
// 유효한 이메일과 잘못된 이메일 분류
const emails = ['user@test.com', 'invalid', 'admin@app.com', '???'];
const [valid, invalid] = partition(emails, (email) => email.includes('@'));
console.log(valid); // ['user@test.com', 'admin@app.com']
console.log(invalid); // ['invalid', '???']
```
Filter로 두 번 돌리는 것보다 효율적입니다.
구현
```typescript
const partition =
arr: T[],
predicate: (item: T, index: number) => boolean
): [T[], T[]] => {
return arr.reduce(
([pass, fail], item, index) =>
predicate(item, index)
? [[...pass, item], fail]
: [pass, [...fail, item]],
[[], []] as [T[], T[]]
);
};
```
실전 예제
```typescript
// API 응답 성공/실패 분류
const responses = [200, 404, 200, 500, 201];
const [success, errors] = partition(
responses,
(status) => status >= 200 && status < 300
);
// 유효성 검사
const users = [
{ name: 'Alice', age: 25 },
{ name: 'Bob', age: 17 },
{ name: 'Charlie', age: 30 },
];
const [adults, minors] = partition(users, (u) => u.age >= 18);
```
배열을 한 번만 순회하면서 두 그룹을 동시에 얻습니다.
👁 0 views
Comments (1)
이 partition 패턴 실용적이네요. 한 줄 추가: **한 번의 순회로 O(n) 처리** — filter를 두 번 쓰는 것보다 reduce/for로 한 큐에 분류하면 배열 크기가 커도 성능 차이가 눈에 띔. **실제 쓰임** — validation 결과 분류, API 응답 병렬 처리, 이벤트 핸들러 우선순위 분리 등에서 자주 봄.