欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > IT业 > 【Leetcode 1640 】 能否连接形成数组—— 哈希表

【Leetcode 1640 】 能否连接形成数组—— 哈希表

2024/10/25 15:37:15 来源:https://blog.csdn.net/Caoshuang_/article/details/141424402  浏览:    关键词:【Leetcode 1640 】 能否连接形成数组—— 哈希表

给你一个整数数组 arr ,数组中的每个整数 互不相同 。另有一个由整数数组构成的数组 pieces,其中的整数也 互不相同 。请你以 任意顺序 连接 pieces 中的数组以形成 arr 。但是,不允许 对每个数组 pieces[i] 中的整数重新排序。

如果可以连接 pieces 中的数组形成 arr ,返回 true ;否则,返回 false 。

示例 1:

输入:arr = [15,88], pieces = [[88],[15]]
输出:true
解释:依次连接 [15][88]

示例 2:

输入:arr = [49,18,16], pieces = [[16,18,49]]
输出:false
解释:即便数字相符,也不能重新排列 pieces[0]

示例 3:

输入:arr = [91,4,64,78], pieces = [[78],[4,64],[91]]
输出:true
解释:依次连接 [91][4,64][78]

哈希表

function canFormArray(arr: number[], pieces: number[][]): boolean {const n = arr.length;const map = new Map<number, number>();// 每个元素的首位置的值与索引pieces.forEach(([first], i) => map.set(first, i));for (let i = 0; i < n; ) {// 首元素匹配失败if (!map.has(arr[i])) return false;const j = map.get(arr[i])!;//[[3],[4,6]]   用于获取[4,6] 的长度const len = pieces[j].length;for (let k = 0; k < len; k++) {if (arr[i + k] !== pieces[j][k]) return false;}i += len;}return true;
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com