zoukankan      html  css  js  c++  java
  • 一元多项式的相乘

      1 #include <iostream>
      2 #include<stdlib.h>
      3 
      4 using namespace std;
      5 
      6 
      7 #define MAXSIZE 20
      8 
      9 typedef struct LNode
     10 {
     11     int coef;//系数
     12     int expn;//指数
     13     struct LNode *next;
     14 }LNode,*LinkList;
     15 
     16 
     17 int CreateList_L(LinkList &L,int n)
     18 {
     19     LinkList p,q;
     20     for(int i=0;i<n;i++)
     21     {
     22          p=(LinkList)malloc(sizeof(LNode));
     23          cout<<"输入元素系数:";
     24          cin>>p->coef;
     25          cout<<"输入元素指数:";
     26          cin>>p->expn;
     27          if(i==0)L=p;
     28          else q->next=p;
     29          q=p;
     30          p->next=NULL;
     31     }
     32    return 0;
     33 }
     34 
     35 
     36 int LengthPolyn(LinkList L)//判断多项式的项数
     37 {
     38     int s=0;
     39     while(L)
     40     {
     41         s++;
     42         L=L->next;
     43     }
     44     return s;
     45 }
     46 
     47 
     48 int CopyList_L(LinkList La,LinkList &Lb)//开辟一段和La指向的空间一样的新的空间,并把La中各元素的值依次复制到Lb中
     49 {
     50     LinkList p,q,pa=La;
     51     int n=LengthPolyn(La);
     52     for(int i=0;i<n;i++)
     53     {
     54          p=(LinkList)malloc(sizeof(LNode));
     55          p->coef=pa->coef;
     56          p->expn=pa->expn;
     57          if(i==0)Lb=p;
     58          else q->next=p;
     59          q=p;
     60          p->next=NULL;
     61          pa=pa->next;
     62     }
     63    return 0;
     64 }
     65 
     66 
     67 
     68 int Display_L(LinkList L)
     69 {
     70     cout<<"f(x)="<<L->coef;
     71     if(L->expn)cout<<"*"<<"x^"<<L->expn;
     72     L=L->next;
     73     while(L)
     74     {
     75         if(L->coef>0)
     76         {
     77             cout<<"+";
     78             cout<<L->coef<<"*"<<"x^"<<L->expn;
     79         }
     80         else cout<<L->coef<<"*"<<"x^"<<L->expn;
     81         L=L->next;
     82     }
     83     return 0;
     84 }
     85 
     86 
     87 
     88 int AddPolyn(LinkList La,LinkList Lb,LinkList &Lc)
     89 {
     90     LinkList pa,pb,p;
     91     int k=1;
     92     pa=La;pb=Lb;
     93     //确定“和多项式”的头结点
     94     while(k)
     95     {
     96          if(pa->expn<pb->expn){p=Lc=pa;pa=pa->next;k=0;}
     97          else if(pa->expn>pb->expn){p=Lc=pb;pb=pb->next;k=0;}
     98          else
     99          {
    100              pa->coef+=pb->coef;
    101              if(pa->coef)
    102              {
    103                   p=Lc=pa;
    104                   pa=pa->next;
    105                   k=0;
    106              }
    107              else
    108              {
    109                  pa=pa->next;
    110                  pb=pb->next;
    111                  if(!pa||!pb) break;
    112              }
    113          }
    114     }
    115     if(!pb&&pa){p=Lc=pa;pa=pa->next;}
    116     if(!pa&&pb){p=Lc=pb;pb=pb->next;}
    117     if(!pa&&!pb) Lc=NULL;
    118     //确定接下来的节点
    119     while(pa&&pb)
    120     {
    121         if(pa->expn<pb->expn){p->next=pa;p=pa;pa=pa->next;}
    122         else if(pa->expn>pb->expn){p->next=pb;p=pb;pb=pb->next;}
    123         else
    124         {
    125             pa->coef+=pb->coef;
    126             if(pa->coef)
    127             {
    128                   p->next=pa;
    129                   p=pa;
    130                   pa=pa->next;
    131                   pb=pb->next;
    132             }
    133             else
    134             {
    135                   pa=pa->next;
    136                   pb=pb->next;
    137             }
    138 
    139         }
    140     }
    141     while(!pb&&pa)
    142     {
    143         p->next=pa;
    144         p=pa;
    145         pa=pa->next;
    146     }
    147     while(!pa&&pb)
    148     {
    149         p->next=pb;
    150         p=pb;
    151         pb=pb->next;
    152     }
    153     return 0;
    154 }
    155 
    156 
    157 
    158 int MultiplyPolyn(LinkList La,LinkList Lb,LinkList &Lc)//La指向的多项式乘以Lb指向的多项式
    159 {
    160     LinkList pa,pb=Lb,l;
    161     int i=0,j,n;
    162     LNode *L[MAXSIZE];//指针数组,Lb至多MAXSIZE项!
    163     while(pb)
    164     {
    165         CopyList_L(La,L[i]);
    166         pa=L[i];
    167         while(pa)
    168         {
    169             pa->coef*=pb->coef;
    170             pa->expn+=pb->expn;
    171             pa=pa->next;
    172         }
    173         pb=pb->next;
    174         i++;
    175     }
    176     n=LengthPolyn(Lb);
    177     AddPolyn(L[0],L[1],Lc);
    178     for(j=2;j<n;j++)
    179     {
    180         AddPolyn(L[j],l,Lc);
    181         l=Lc;
    182     }
    183     return 0;
    184 }
    185 
    186 
    187 
    188 int main()
    189 {
    190     LinkList La,Lb,Lc;
    191     int m,n;
    192     cout<<"请输入La中的元素个数:";
    193     cin>>m;
    194     CreateList_L(La,m);
    195     cout<<"请输入Lb中的元素个数:";
    196     cin>>n;
    197     CreateList_L(Lb,n);
    198     MultiplyPolyn(La,Lb,Lc);
    199     Display_L(Lc);
    200     return 0;
    201 }

    只有0和1的世界是简单的
  • 相关阅读:
    关于一个简单面试题(。net)
    写一个TT模板自动生成spring.net下面的配置文件。
    EF自动生成的(T4模板) 关联属性元数据修改
    关于面向切面编程的部分内容-错误处理机制
    memcache 安装
    Newtonsoft.Json工具类
    关于Memcache使用的工具类
    关于 Log4Net
    今天开始写博客
    OC 协议
  • 原文地址:https://www.cnblogs.com/nullxjx/p/5903192.html
Copyright © 2011-2022 走看看