有序顺序表的合并

该博客展示了如何使用C语言实现顺序表的初始化、插入操作,并通过归并排序的方式合并两个有序顺序表。代码中定义了顺序表结构,提供了初始化、插入和合并的函数,以及显示顺序表内容的辅助函数。在主函数中,创建了两个有序顺序表并进行合并展示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#define _CRT_SECURE_NO_WARNINGS//顺序表
#include <stdio.h>
#include <malloc.h>

//全局定义特殊变量
#define MAX 50
#define ok 1
#define OVERFLOW 0

//转定义区域
typedef int ElemType;
typedef int status;

typedef struct//定义一个初始化的顺序表
{
	ElemType* elem;//基地址
	int length;
}Sqlist;

status initlist(Sqlist &L)
{
	L.elem = new ElemType[MAX];
	if (!L.elem)
	{
		return OVERFLOW;
	}
	L.length = 0;
	return ok;
}

status insertlist(Sqlist& L, int i,ElemType e)
{
	int j;
	if (i<1 || i>L.length + 1)
	{
		return 0;
	}
	if (L.length == MAX)
	{
		return 0;
	}
	for (j = L.length - 1; j >= i - 1; j--)
	{
		L.elem[j + 1] = L.elem[j];
	}
	L.elem[i - 1]=e;
	++L.length;
	return ok;
}

status MergeList_sq(Sqlist& L1, Sqlist& L2, Sqlist& L3)
{
	ElemType* p1, * p2, * p3, * p1_last, * p2_last;
	L3.length = L1.length + L2.length;
	L3.elem = new ElemType[L3.length];
	p1 = L1.elem; p2 = L2.elem; p3 = L3.elem;
	p1_last = &L1.elem[L1.length];
	p2_last = &L2.elem[L2.length];
	while (p1 != p1_last && p2 != p2_last)
	{
		if (*p1 <= *p2)
		{
			*p3++ = *p1++;
		}
		else
		{
			*p3++ = *p2++;
		}
	}
	while (p1 != p1_last)
	{
		*p3++ = *p1++;
	}
	while (p2 != p2_last)
	{
		*p3++ = *p2++;
	}
    return ok;
}

void Displist(Sqlist L)
{
	int i=0;
	while (i < L.length)
	{
		printf("%d  ", L.elem[i]);
		i++;
	}
	printf("\n");
}

int main()
{
	int a, f , i;
	ElemType e = 0;
	Sqlist L1;//定义好顺序表
	Sqlist L2;//定义好顺序表
	Sqlist L3;//定义好顺序表
	initlist(L1);
	initlist(L2);
	for (i = 1,f=1; i < 10; i += 2,f++)
	{
		insertlist(L1, f, i);
	}
	for (i = 2, f = 1; i < 10; i += 2, f++)
	{
		insertlist(L2, f, i);
	}
	MergeList_sq(L1, L2, L3);
	printf("生成的串1:");
	Displist(L1);
	printf("生成的串2:");
	Displist(L2);
	printf("合并的串:");
	Displist(L3);
	return ok;
	
	
}

使用的编译器环境是vs2019,源文件后缀是.cpp

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值