以下是一个按顺序合并数组的解决方法的代码示例:
def merge_arrays(arr1, arr2):
merged_array = []
i = 0
j = 0
while i < len(arr1) and j < len(arr2):
if arr1[i] < arr2[j]:
merged_array.append(arr1[i])
i += 1
else:
merged_array.append(arr2[j])
j += 1
while i < len(arr1):
merged_array.append(arr1[i])
i += 1
while j < len(arr2):
merged_array.append(arr2[j])
j += 1
return merged_array
# 示例用法
arr1 = [1, 3, 5, 7]
arr2 = [2, 4, 6, 8]
merged = merge_arrays(arr1, arr2)
print(merged) # 输出 [1, 2, 3, 4, 5, 6, 7, 8]
这个解决方法使用了两个指针 i
和 j
分别追踪 arr1
和 arr2
当前要比较的元素的索引。在每一次循环中,比较 arr1[i]
和 arr2[j]
的值,将较小的值添加到 merged_array
中,并将对应的指针向后移动一位。当其中一个数组的所有元素都被添加到 merged_array
后,再将剩余数组的元素依次添加到 merged_array
中。最后返回合并后的数组。
上一篇:按顺序合并数据框的列表
下一篇:按顺序合并以字符分隔的列