有序表归并函数C语言,两个有序单链表的合并c语言

数据结构:顺序表的合并(C语言)

#include stdio.h

创新互联建站是专业的樊城网站建设公司,樊城接单;提供网站设计、成都网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行樊城网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!

#include malloc.h

#include stdlib.h

#define LIST_INIT_SIZE 10 // 线性表存储空间的初始分配量

#define LISTINCREMENT 2 // 线性表存储空间的分配增量

struct SqList

{

int *elem; // 存储空间基址

int length; // 当前长度

int listsize; // 当前分配的存储容量(以sizeof(int)为单位)

};

void InitList(SqList L)

{ // 操作结果:构造一个空的顺序线性表

L.elem = (int *)malloc(LIST_INIT_SIZE*sizeof(int));

if (!L.elem)

exit(0); // 存储分配失败

L.length = 0; // 空表长度为0

L.listsize = LIST_INIT_SIZE; // 初始存储容量

}

int ListInsert(SqList L, int i, int e)

{ // 初始条件:顺序线性表L已存在,1≤i≤ListLength(L)+1

// 操作结果:在L中第i个位置之前插入新的数据元素e,L的长度加1

int *newbase, *q, *p;

if (i1 || iL.length + 1) // i值不合法

return 0;

if (L.length = L.listsize) // 当前存储空间已满,增加分配

{

if (!(newbase = (int *)realloc(L.elem, (L.listsize + LISTINCREMENT)*sizeof(int))))

exit(0); // 存储分配失败

L.elem = newbase; // 新基址

L.listsize += LISTINCREMENT; // 增加存储容量

}

q = L.elem + i - 1; // q为插入位置

for (p = L.elem + L.length - 1; p = q; --p) // 插入位置及之后的元素右移

*(p + 1) = *p;

*q = e; // 插入e

++L.length; // 表长增1

return 1;

}

void Print(SqList L)

{

int i;

for (i = 0; iL.length; i++)

printf("%d ", *(L.elem + i));

printf("\n");

}

// ————————————————————————————————————

// 函数①

void MergeList1(SqList La, SqList Lb, SqList Lc)

{

int *pa, *pa_last, *pb, *pb_last, *pc;

pa = La.elem;

pb = Lb.elem;

Lc.listsize = Lc.length = La.length + Lb.length;//不用InitList()创建空表Lc

pc = Lc.elem = (int *)malloc(Lc.listsize*sizeof(int));

if (!Lc.elem) // 存储分配失败

exit(0);

pa_last = La.elem + La.length - 1;

pb_last = Lb.elem + Lb.length - 1;

while (pa = pa_lastpb = pb_last) // 表La和表Lb均非空

{ // 归并

if (*pa  *pb)

*pc++ = *pa++;

else if (*pa  *pb)

*pc++ = *pb++;

else{

*pc++ = *pa++;

pb++;

Lc.length--;

}

}

while (pa = pa_last) // 表La非空且表Lb空

*pc++ = *pa++; // 插入La的剩余元素

while (pb = pb_last) // 表Lb非空且表La空

*pc++ = *pb++; // 插入Lb的剩余元素

}

// ————————————————————————————————————

// 函数②

void MergeList2(SqList La, SqList Lb, SqList Lc)

{

int *pa, *pa_last, *pb, *pb_last, *pc;

pa = La.elem;

pb = Lb.elem;

Lc.listsize = Lc.length = La.length + Lb.length;//不用InitList()创建空表Lc

pc = Lc.elem = (int *)malloc(Lc.listsize*sizeof(int));

if (!Lc.elem) // 存储分配失败

exit(0);

pa_last = La.elem + La.length - 1;

pb_last = Lb.elem + Lb.length - 1;

while (pa = pa_lastpb = pb_last) // 表La和表Lb均非空

{ // 归并

if (*pa = *pb)

*pc++ = *pa++;

else

*pc++ = *pb++;

}

while (pa = pa_last) // 表La非空且表Lb空

*pc++ = *pa++; // 插入La的剩余元素

while (pb = pb_last) // 表Lb非空且表La空

*pc++ = *pb++; // 插入Lb的剩余元素

Lb.length = Lc.length;

Lb = Lc;

}

// ————————————————————————————————————

// 函数③

void Inverse(SqList L){

int i, t;

for (i = 0; i  L.length / 2; i++)

{

t = *(L.elem + i);

*(L.elem + i) = *(L.elem + L.length - i - 1);

*(L.elem + L.length - i - 1) = t;

}

}

void main(){

SqList LA, LB, LC;

int a[4] = { 3, 5, 8, 11 }, b[7] = { 2, 6, 8, 9, 11, 15, 20 };

int i;

InitList(LA);

InitList(LB);

InitList(LC);

for (i = 0; i  4; i++)

ListInsert(LA, i + 1, a[i]);

for (i = 0; i  7; i++)

ListInsert(LB, i + 1, b[i]);

printf("LA=");

Print(LA);

printf("LB=");

Print(LB);

printf("\n");

MergeList1(LA, LB, LC);

printf("①LC=");

Print(LC);

printf("\n");

MergeList2(LA, LB, LC);

printf("②LB=");

Print(LB);

printf("\n");

printf("③LC=");

Inverse(LC);

Print(LC);

}

C语言编写一个程序实现两个有序(从小到大)顺序表合并成为一个顺序表,合并后的结果放在第一个顺序表中。

你提到的“奇怪错误”是由于你的exit宏和函数重名了,所以预处理器会把程序中的exit用-1代替,所以出错。

另外,你的合并函数也是错误的,无法达到要求,整个程序修改如下:

//---------------------------------------------------------------------------

#include stdio.h

#include stdlib.h //注意这里,exit()函数要用到这个文件,这个文件已经包含了malloc()等函数的声明

#define OK 1

#define LIST_INIT_SIZE 100

#define OVERFLOW 0

#define EXIT -2 //************注意这里

typedef int ElemType;

typedef int Status;

typedef struct {

ElemType *elem;

int length;

int listsize;

}SqList;

Status InitList_Sq(SqList *L)

{ L-elem=(ElemType *)malloc(LIST_INIT_SIZE*sizeof(ElemType));

if(!L-elem) exit(OVERFLOW);

L-length=0;

L-listsize=LIST_INIT_SIZE;

return OK;

}

void Create_Sq(SqList *L)

{ int i,n;

printf("创建一个有序表:\n");

printf("输入有序表中元素的个数:");

scanf("%d",n);

L-length=n;

for(i=0;in;i++){

printf("输入第%d个元素的值:",i+1);

scanf("%d",L-elem[i]);

printf("\n");

}

}

void Disp_Sq(SqList *L) //************注意这里

{ int i,n;

n=L-length;

for(i=0;in;i++)

printf("%5d",L-elem[i]);

printf("\n");

}

void Combine(SqList *la,SqList *lb) //************注意这里,此函数被重新编写

{

ElemType *pa=la-elem,*pb=lb-elem ;

int i,j,k,len_a=la-length,len_b=lb-length;

if ((la-elem=malloc((len_a+len_b)*sizeof(ElemType)))==NULL) exit(OVERFLOW);

for (k=i=j=0; ilen_ajlen_b; ) {

if (pa[i]pb[j]) la-elem[k++]=pa[i++];

else la-elem[k++]=pb[j++];

}

while (ilen_a)

la-elem[k++]=pa[i++];

while (jlen_b)

la-elem[k++]=pb[j++];

la-length=k;

la-listsize=k;

free(pa);

}

void main()

{SqList L1,L2;

InitList_Sq(L1);

InitList_Sq(L2);

Create_Sq(L1);

Disp_Sq(L1);

printf("\n");

Create_Sq(L2);

Disp_Sq(L2); //************注意这里

printf("\n");

Combine(L1,L2);

Disp_Sq(L1); //************注意这里

}

//---------------------------------------------------------------------------

c语言编程,两个有序表其元素为递增有序,将此两表归并成一新的有序表并保持递增

sqlist union(sqlist sa,sqlist sb)

{int sc[maxsize];

sa.length=length(sa);

sb.length=length(sb);

maxsize=sa.length+sb.length;

i=0;

while(isa.lengthisb.length)

{j=0;

if(sa[i]=sb[i]) {sc[j]=sa[i];j++}

i++;

}

while(isa.lengthisb.length)

{sc[j]=sa[i]?sa[i]:sb[i];i++;j++;}

}

解释下面C语言程序(合并顺序表,有顺序表La,Lb)

因为顺序表La、Lb都已经排好序了,那么要将他们合并成有序表放在Lc中,将La和Lb从他们的初始元素进行比较,谁小就将谁放入到Lc中,同时Lc和放入元素的顺序表都指向下一个元素,然后继续循环。最后肯定会有一个顺序表先为空,那么就把不为空的顺序表中的元素直接复制到表Lc中即可。


本文名称:有序表归并函数C语言,两个有序单链表的合并c语言
文章起源:http://myzitong.com/article/hssigp.html