05链表案例之多项式相加

链表案例之多项式相加

#include<stdio.h>
#include<stdlib.h>
#define TRUE 1
#define ERROR 1
#define FALSE 0
#define OK 1
#define INFEASIBLE -1
#define OVERFLOW -2
typedef int Status; 

//定义结点 
typedef struct Lnode{
	int data;
	int e;
	struct Lnode *next;
}Lnode, *LinkList;

// 尾插法创建链表
void CreateList_R(LinkList &L, int n){	//Create创建 ,_R尾插法 ,参数LinkList &L为头指针,参数n为链表的结点个数 
	L=(LinkList)malloc(sizeof(Lnode));	//让指针L指向一个空结点 
	L->next=NULL;	//先建立一个带头结点的单链表
	Lnode *r=L;		//定义一个结点指针r作为尾指针 ,初始化指向头结点(只有一个结点是头结点则为尾结点) 
	printf("请输入项数为%d多项式,以空格隔开:\n",n);
	for(int i=1;i<=n;i++){
		Lnode *p;	//定义一个结点指针p 
		p=(LinkList)malloc(sizeof(Lnode));	//为结点指针开辟一个结点;
		scanf("%d*x**%d",&p->data,&p->e); 	//为结点p的数据域赋值
		p->next=NULL;	  //因为是尾插法,所以新创建的结点必须为尾结点则指针域为空
		r->next=p;		 //r原来指的尾结点成为倒数第二个结点,所以该结点的指针域指向尾结点p 
		r=p; 		    //由因为p为尾结点,则将p赋值给r,则r为尾结点,即r成为新的尾指针指向尾结点。 
		
	} 
}  

// 多项式求和
void SumList(LinkList &La,LinkList &Lb){
	LinkList pa,pb,pc;
	pa=La->next;	//pa指向La的首元结点 
	pb=Lb->next;	//pb指向Lb的首元结点
	pc=La;			//pc指向La的头结点
	Lnode *Lc=La;	//令Lc为Lc的头结点 
	while(pa&&pb){	//La和Lb一旦有一个排完则跳出循环 
		if(pa->e<pb->e){
			pc->next=pa;		//将pa赋值给Lc的首元结点 
			pa=pa->next; 	  	//pa指向下一个结点
		}
		else if(pa->e==pb->e){
			pa->data=pa->data+pb->data;系数相加
			pc->next=pa;	//将pa赋值给Lc的首元结点 	 
			pa=pa->next;	//pa指向下一个结点	
			pb=pb->next; 	//pb指向下一个结点 
		} 
		else{	
			pc->next=pb;	//将pb赋值给Lc的首元结点 	
			pb=pb->next; 	//pb指向下一个结点 
		} 
		pc=pc->next;	//pc指向下一个结点
	}
	pc->next=pa?pa:pb; //将未排的加到后面
	free(Lb);
} 

//	输出链表
void PrintList_L(LinkList &L){
	Lnode *p;
	int count=0;
	p=L->next;
	while(p){
		printf("%d*x**%d ",p->data,p->e);
		p=p->next;
		count++;	
	}
	printf("\n链表的长度为%d(不包含头结点)",count);
	printf("\n----------------------------\n");
} 

int main(){
	LinkList LA,LB;
	CreateList_R(LA,5);
	PrintList_L(LA);
	CreateList_R(LB,3);
	PrintList_L(LB);
	SumList(LA,LB);
	PrintList_L(LA);
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿明同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值