// Copyright 2018-2026 the Deno authors. MIT license. // This module is browser compatible. /** * Builds N-tuples of elements from the given N arrays with matching indices, * stopping when the smallest array's end is reached. * * @typeParam T The type of the tuples produced by this function. * * @param arrays The arrays to zip. * * @returns A new array containing N-tuples of elements from the given arrays. * * @example Basic usage * ```ts * import { zip } from "zip.ts"; * import { assertEquals } from "../assert/mod.ts"; * * const numbers = [1, 2, 3, 4]; * const letters = ["a", "b", "c", "d"]; * const pairs = zip(numbers, letters); * * assertEquals( * pairs, * [ * [1, "a"], * [2, "b"], * [3, "c"], * [4, "d"], * ], * ); * ``` */ export function zip( ...arrays: { [K in keyof T]: ReadonlyArray } ): T[] { const { length } = arrays; if (length === 0) return []; let minLength = arrays[0]!.length; for (let i = 1; i < length; ++i) { if (arrays[i]!.length < minLength) { minLength = arrays[i]!.length; } } const result: T[] = new Array(minLength); for (let i = 0; i < minLength; ++i) { const tuple: unknown[] = new Array(length); for (let j = 0; j < length; ++j) { tuple[j] = arrays[j]![i]; } result[i] = tuple as T; } return result; }