用c语言表示两个非递减有序线性表的合并
时间: 2023-09-13 12:07:52 浏览: 125
假设有两个非递减有序线性表 A 和 B,它们的长度分别为 m 和 n,现在要将它们合并为一个非递减有序线性表 C。可以使用双指针的方法,从头开始遍历 A 和 B,将较小的元素加入到 C 中,直到遍历完其中一个线性表,再将另一个线性表的剩余元素加入到 C 中。具体实现如下:
```c
void merge(int A[], int m, int B[], int n, int C[]) {
int i = 0, j = 0, k = 0;
while (i < m && j < n) {
if (A[i] <= B[j]) {
C[k] = A[i];
i++;
} else {
C[k] = B[j];
j++;
}
k++;
}
while (i < m) {
C[k] = A[i];
i++;
k++;
}
while (j < n) {
C[k] = B[j];
j++;
k++;
}
}
```
其中,A 和 B 是待合并的两个非递减有序线性表,m 和 n 是它们的长度,C 是合并后的结果。初始化三个指针 i、j、k 分别指向 A、B、C 的起始位置,当 A[i] <= B[j] 时,将 A[i] 加入到 C 中,并将 i 指针后移一位;否则将 B[j] 加入到 C 中,并将 j 指针后移一位。当其中一个线性表遍历完后,将另一个线性表的剩余元素依次加入到 C 中即可。
阅读全文