将两个顺序表合并成一个顺序表的c语言代码
时间: 2023-09-08 17:12:37 浏览: 172
实验一_C语言_
你可以使用以下的C语言代码将两个顺序表合并成一个顺序表:
```c
#include <stdio.h>
void mergeArrays(int arr1[], int size1, int arr2[], int size2, int mergedArr[]) {
int i = 0, j = 0, k = 0;
while (i < size1 && j < size2) {
if (arr1[i] < arr2[j]) {
mergedArr[k++] = arr1[i++];
} else {
mergedArr[k++] = arr2[j++];
}
}
while (i < size1) {
mergedArr[k++] = arr1[i++];
}
while (j < size2) {
mergedArr[k++] = arr2[j++];
}
}
int main() {
int arr1[] = {1, 3, 5, 7, 9};
int size1 = sizeof(arr1) / sizeof(arr1[0]);
int arr2[] = {2, 4, 6, 8, 10};
int size2 = sizeof(arr2) / sizeof(arr2[0]);
int mergedArr[size1 + size2];
mergeArrays(arr1, size1, arr2, size2, mergedArr);
printf("Merged Array: ");
for (int i = 0; i < size1 + size2; i++) {
printf("%d ", mergedArr[i]);
}
return 0;
}
```
这段代码中,`mergeArrays`函数接收两个顺序表`arr1`和`arr2`,以及它们的大小`size1`和`size2`,还有一个用于存储合并结果的顺序表`mergedArr`。函数中使用三个指针`i`、`j`和`k`来遍历两个输入数组和输出数组,根据大小比较将元素依次存入`mergedArr`中。最后,在`main`函数中创建一个足够大的数组`mergedArr`来存储合并结果,并打印出合并后的顺序表。
请注意,这段代码假设输入的两个顺序表已经按照升序排列。如果没有按照升序排列,则需要在合并前对两个顺序表进行排序。
阅读全文