帮我用C语言写一段顺序有序表合并的代码
时间: 2024-05-08 11:18:46 浏览: 79
数据结构C语言实验
好的,以下是用C语言实现顺序有序表合并的代码:
```c
#include <stdio.h>
#include <stdlib.h>
#define MAXSIZE 100 // 最大长度
typedef struct {
int data[MAXSIZE];
int length;
} SqList;
// 初始化顺序表
void initList(SqList *L) {
L->length = 0;
}
// 添加元素
void addElement(SqList *L, int element) {
if (L->length >= MAXSIZE) {
printf("List is full, cannot add element.\n");
return;
}
L->data[L->length++] = element;
}
// 合并两个有序表
void merge(SqList La, SqList Lb, SqList *Lc) {
int i = 0, j = 0, k = 0;
while (i < La.length && j < Lb.length) {
if (La.data[i] < Lb.data[j]) {
Lc->data[k++] = La.data[i++];
} else {
Lc->data[k++] = Lb.data[j++];
}
}
while (i < La.length) {
Lc->data[k++] = La.data[i++];
}
while (j < Lb.length) {
Lc->data[k++] = Lb.data[j++];
}
Lc->length = k;
}
// 输出顺序表
void printList(SqList L) {
for (int i = 0; i < L.length; i++) {
printf("%d ", L.data[i]);
}
printf("\n");
}
int main() {
SqList La, Lb, Lc;
initList(&La);
initList(&Lb);
initList(&Lc);
// 测试数据
addElement(&La, 1);
addElement(&La, 3);
addElement(&La, 4);
addElement(&La, 5);
addElement(&Lb, 2);
addElement(&Lb, 4);
addElement(&Lb, 6);
addElement(&Lb, 8);
merge(La, Lb, &Lc);
printf("La: ");
printList(La);
printf("Lb: ");
printList(Lb);
printf("Lc: ");
printList(Lc);
return 0;
}
```
以上代码实现了合并两个顺序有序表,并输出合并后的结果。如果有需要,可以根据自己的需求修改代码。
阅读全文