mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-10 18:48:13 +08:00
78 lines
3.5 KiB
HTML
78 lines
3.5 KiB
HTML
<p>Given two arrays <code>arr1</code> and <code>arr2</code>, return a new array <code>joinedArray</code>. All the objects in each of the two inputs arrays will contain an <code>id</code> field that has an integer value. <code>joinedArray</code> is an array formed by merging <code>arr1</code> and <code>arr2</code> based on their <code>id</code> key. The length of <code>joinedArray</code> should be the length of unique values of <code>id</code>. The returned array should be sorted in <strong>ascending</strong> order based on the <code>id</code> key.</p>
|
|
|
|
<p>If a given <code>id</code> exists in one array but not the other, the single object with that <code>id</code> should be included in the result array without modification.</p>
|
|
|
|
<p>If two objects share an <code>id</code>, their properties should be merged into a single object:</p>
|
|
|
|
<ul>
|
|
<li>If a key only exists in one object, that single key-value pair should be included in the object.</li>
|
|
<li>If a key is included in both objects, the value in the object from <code>arr2</code> should override the value from <code>arr1</code>.</li>
|
|
</ul>
|
|
|
|
<p> </p>
|
|
<p><strong class="example">Example 1:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input:</strong>
|
|
arr1 = [
|
|
{"id": 1, "x": 1},
|
|
{"id": 2, "x": 9}
|
|
],
|
|
arr2 = [
|
|
{"id": 3, "x": 5}
|
|
]
|
|
<strong>Output:</strong>
|
|
[
|
|
{"id": 1, "x": 1},
|
|
{"id": 2, "x": 9},
|
|
{"id": 3, "x": 5}
|
|
]
|
|
<strong>Explanation:</strong> There are no duplicate ids so arr1 is simply concatenated with arr2.
|
|
</pre>
|
|
|
|
<p><strong class="example">Example 2:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input:</strong>
|
|
arr1 = [
|
|
{"id": 1, "x": 2, "y": 3},
|
|
{"id": 2, "x": 3, "y": 6}
|
|
],
|
|
arr2 = [
|
|
{"id": 2, "x": 10, "y": 20},
|
|
{"id": 3, "x": 0, "y": 0}
|
|
]
|
|
<strong>Output:</strong>
|
|
[
|
|
{"id": 1, "x": 2, "y": 3},
|
|
{"id": 2, "x": 10, "y": 20},
|
|
{"id": 3, "x": 0, "y": 0}
|
|
]
|
|
<strong>Explanation:</strong> The two objects with id=1 and id=3 are included in the result array without modifiction. The two objects with id=2 are merged together. The keys from arr2 override the values in arr1.
|
|
</pre>
|
|
|
|
<p><strong class="example">Example 3:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input:</strong>
|
|
arr1 = [
|
|
{"id": 1, "b": {"b": 94},"v": [4, 3], "y": 48}
|
|
]
|
|
arr2 = [
|
|
{"id": 1, "b": {"c": 84}, "v": [1, 3]}
|
|
]
|
|
<strong>Output:</strong> [
|
|
{"id": 1, "b": {"c": 84}, "v": [1, 3], "y": 48}
|
|
]
|
|
<strong>Explanation:</strong> The two objects with id=1 are merged together. For the keys "b" and "v" the values from arr2 are used. Since the key "y" only exists in arr1, that value is taken form arr1.</pre>
|
|
|
|
<p> </p>
|
|
<p><strong>Constraints:</strong></p>
|
|
|
|
<ul>
|
|
<li><code>arr1 and arr2 are valid JSON arrays</code></li>
|
|
<li><code>Each object in arr1 and arr2 has a unique integer id key</code></li>
|
|
<li><code>2 <= JSON.stringify(arr1).length <= 10<sup>6</sup></code></li>
|
|
<li><code>2 <= JSON.stringify(arr2).length <= 10<sup>6</sup></code></li>
|
|
</ul>
|