zoukankan      html  css  js  c++  java
  • 多项式相乘与相加演示

    #include<stdio.h>
    #include<stdlib.h>
    typedef struct node
    {
        int p;
    	int e;
    	struct node *next;
    }Polynomial,*P_Polynomial;
    P_Polynomial  Input()
    {//输入多项式
    	P_Polynomial p1,p2,head;
    	head=p2=(P_Polynomial)malloc(sizeof(Polynomial));
    	p1=(P_Polynomial)malloc(sizeof(Polynomial));
    	printf("
    请输入多项式的系数和幂值
    (注:以幂值为0结束)
    ");
    	scanf("%d %d",&p1->p,&p1->e);
        while(p1->e!=0)
    	{
    		p2->next=p1;
    		p2=p1;
            p1=(P_Polynomial)malloc(sizeof(Polynomial));
    		scanf("%d %d",&p1->p,&p1->e);
    	}
    	p2->next=NULL;
    	free(p1);
    	return head;
    }
    void Add_polynomial(P_Polynomial p1,P_Polynomial p2)
    {//多项式相加
    	P_Polynomial pre_p1,cur_p1,cur_p2;
    	pre_p1=p1;//p1的前指针
    	cur_p1=p1->next;
    	cur_p1=p2->next;// p1和p2的当前指针
    	while(cur_p1&&cur_p2)
    	{
    		if(cur_p1->e==cur_p2->e)// 如果p1和p2的幂相等,则相加并入p1
    		{
    			cur_p1->p=cur_p1->p+cur_p2->p;
    			if(cur_p1->p==0)//if p==0
    			{
    				pre_p1->next=cur_p1->next;
    				free(cur_p1);
    				cur_p1=pre_p1->next;
    				cur_p2=cur_p2->next;		
    			}
    			else// if p!=0
    			{
    				pre_p1=cur_p1;
    				cur_p1=cur_p1->next;
    				cur_p2=cur_p2->next;
    			}
    		}
    		continue;//continue find...
    		if(cur_p1->e<cur_p2->e)
    		{
    			pre_p1=cur_p1;
    			cur_p1=cur_p1->next;
    		}
    		else
    		{
    			P_Polynomial temp;
    			if(!(temp=(P_Polynomial)malloc(sizeof(Polynomial))))
    			{
    				printf("内存不足。。。");
    				exit(0);
    			}
    			temp->p=cur_p2->p;
    			temp->e=cur_p2->e;
    			temp->next=cur_p1;
    			pre_p1->next=temp;
    			pre_p1=pre_p1->next;
    			cur_p2=cur_p2->next;//在p1中插入p2
    		}
    	}
    	while(cur_p2)
    	{
    		P_Polynomial temp;
    		if(!(temp=(P_Polynomial)malloc(sizeof(Polynomial))))
    		{
    				printf("内存不足。。。");
    				exit(0);
    		}
    		temp->p=cur_p2->p;
    		temp->e=cur_p2->e;
    		temp->next=NULL;
    		pre_p1->next=temp;
    		pre_p1=pre_p1->next;
    		cur_p2=cur_p2->next;
    	}
    }
    P_Polynomial Mul_polynomial(P_Polynomial *exp1,P_Polynomial *exp2)
    {//多项式相乘
    	P_Polynomial head,p1,p2,last,pre,px,q;
    	int flag=1;
    	head=p1=*exp1;
    	p1=p1->next;
    	for(;p1->next!=NULL;p1=p1->next);
    	px=last=p1;
    	p1=(*exp1)->next;
    	while(p1!=px->next)
    	{
    		pre=p1;
    		flag=1;
    		p2=(*exp2)->next;
    		while(p2)
    		{
    			if(flag)
    			{
    				p1->p=p1->p*p2->p;
    				p1->e=p1->e+p2->e;
    				p2=p2->next;
    				flag=0;
    			}
    			else
    			{
    			   q=(P_Polynomial)malloc(sizeof(Polynomial));
    			   q->p=pre->p*p2->p;
    			   q->e=pre->e+p2->e;
                   last->next=q;
    			   last=q;
    			   p2=p2->next;
    			}
    		}
          p1=p1->next;
    	  last->next=NULL;
    	}
    	return head;
    }
    P_Polynomial Sort_polynomial(P_Polynomial pol)
    {//对多项式排序,
    	P_Polynomial head=pol,p,q,r,t;
    	if(head->next==NULL)
    		printf("input error!!!	");
    	else
    	{
          p=head->next;
    	  q=p->next;
    	  p->next=NULL;
    	  p=q;
    	}
    	while(p!=NULL)
    	{
    		r = head;
    		q = r->next;
    		while(q != NULL&& q->e < p->e)
    		{
    			r = q;
    			q = q->next;
    		}
             t=p->next; 
    	     p->next=r->next;
    		 r->next=p;
    		 p=t;
    	}
    	return(head);
    }
    P_Polynomial Combine_polynomial(P_Polynomial head)
    {//对指数相同的多项式进行合并。。
    	P_Polynomial p1,p2;
    	p1=head->next;
    	while(p1->next!=NULL)
    	{
    		if(p1->next->e==p1->e)
    		{
    			p2=p1->next;
    			p1->e=p1->e+p2->e;
    			p1->next=p1->next->next;
    			free(p2);
    		}
    		else
    		{
    			p1=p1->next;
    		}
    	}
    	return head;
    }
    void output(P_Polynomial head)
    {
    	P_Polynomial p1;
    	p1=head->next;
    	while(p1!=NULL)
    	{
    		if(p1->e<0&&p1!=NULL)
    	       printf("");
    		printf("%dX(%d)+",p1->p,p1->e);
    		p1=p1->next;
    	}
    	printf("");
    	printf("
    ");
    }
    int main()
    {
    	P_Polynomial p1,p2,add,mul;
    	printf("please input p1:
    ");
    	p1=Input();
    	printf("please input p2:
    ");
    	p2=Input();
    //	printf("p1+p2=");
    //	   add=Add_polynomial(p1,p2);
    	//   output(add);n
    	printf("p1*p2=");
    	   mul=Mul_polynomial(&p1,&p2);
    	   Sort_polynomial(mul);
    	   Combine_polynomial(mul);
    	   output(mul);
      return 0;
    	
    }


  • 相关阅读:
    2407: C语言习题 整数转换成字符串
    2484: 字母图形
    1658: Easier Done Than Said?
    Easier Done Than Said?(应用到的知识)
    1653: Champion of the Swordsmanship
    1614: 五位以内的对称素数
    1612: 最小公倍数
    $ vs $()
    数学
    计算机科学与技术课程
  • 原文地址:https://www.cnblogs.com/snake-hand/p/3191949.html
Copyright © 2011-2022 走看看