• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天之道

            享受編程的樂趣。
            posts - 118, comments - 7, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            一元多項式相加實現

            Posted on 2012-09-23 15:48 hoshelly 閱讀(1174) 評論(1)  編輯 收藏 引用 所屬分類: DS && Algorithm
            2.3x4+3.2x3+2x2+1.2x與5.6x5-2.3x4+3.4x3
            相加結果為:5.6x5+6.6x3 +2x2+1.2x
            首先考慮存儲結構,多項式中的每一項包括“系數”和“指數”兩項,且相加運算可能會改變系數和指數,故應采用鏈式存儲結構。在一個單鏈表結點中,存儲多項式一項的系數和指數。其次,考慮多項式的運算規則:對于兩個一元多項式中所有指數相同的項,對應系數相加,若和不為0,則構成“和多項式”中的一項;對于兩個一元多項式中所有指數不同的項,則分別復抄到“和多項式”中去。


            #include  <iostream>
            using  namespace  std;
                
                typedef struct{
                float  coef;   //系數
                int expn;        //指數
            }DataType;

            struct Node;
            typedef struct Node *PNode;
            struct Node{
                DataType info;
                PNode link;
            };
            typedef  struct  Node *LinkList;

            typedef  LinkList  polynomial;    //帶頭結點的單鏈表表示多項式

            int cmp(DataType a,DataType b){
                int flag;
                if(a.expn<b.expn) flag=-1;
                else if(a.expn==b.expn)    flag=0;
                else flag=1;
                return flag;
            }

            //建立多項式單鏈表
            void CreatPolyn(polynomial &P,int m){    //m為多項式項數
                polynomial r,s;
                P=new struct Node;
                r=P;
                for(int i=0;i<m;i++){
                    s=new struct Node;
                    cout<<"輸入系數和指數:";
                    cin>>s->info.coef>>s->info.expn;
                    r->link=s;
                    r=s;
            }
            r->link=NULL;
            }

            //多項式相加得到新的多項式
            polynomial AddPolyn(polynomial &pa,polynomial &pb){
                polynomial newp,p,q,s,r;
                float sum;
                p=pa->link;
                q=pb->link;
                newp=new struct Node;
                r=newp;
                while(p&&q){
                    switch(cmp(p->info,q->info)){    //比較兩個多項式的指數
                    case -1:        //多項式pa當前結點的指數值小
                        s=new struct Node;
                        s->info.coef=q->info.coef;
                        s->info.expn=q->info.expn;
                        r->link=s;
                        r=s;
                        q=q->link;
                        break;
                    case 0:        //兩個多項式指數值相等
                        sum=p->info.coef+q->info.coef;
                        if (sum!=0.0){
                            s=new struct Node;
                            s->info.coef=sum;
                            s->info.expn=p->info.expn;
                            r->link=s;
                            r=s;
                        }
                        p=p->link;
                        q=q->link;
                        break;
                    case 1:        //多項式pb當前結點的指數值小
                        s=new struct Node;
                        s->info.coef=p->info.coef;
                        s->info.expn=p->info.expn;
                        r->link=s;
                        r=s;
                        p=p->link;
                        break;
                    }//switch
                }//while

            //鏈接pa剩余結點
            while(p){
                s=new struct Node;
                s->info.coef=p->info.coef;
                s->info.expn=p->info.expn;
                r->link=s;
                r=s;
                p=p->link;
            }
            //鏈接pb剩余結點
            while(q){
                s=new struct Node;
                s->info.coef=q->info.coef;
                s->info.expn=q->info.expn;
                r->link=s;
                r=s;
                q=q->link;
            }
            r->link=NULL;
            return newp;
            }    
            //輸出多項式單鏈表
            void PrintPolyn(polynomial p){
                polynomial s;
                s=p->link;
                while(s){
                //輸出系數和指數
                cout<<s->info.coef<<"("<<s->info.expn<<")";
                s=s->link;
            }
            cout<<endl;
            }
                void main(){
                int m,n;
                polynomial p,q;
                cout<<"請輸入多項式pa的項數:";
                cin>>m;
                CreatPolyn(p,m);
                cout<<"請輸入多項式pb的項數:";
                cin>>n;
                CreatPolyn(q,n);
                PrintPolyn(p);
                PrintPolyn(q);
                PrintPolyn(AddPolyn(p,q));
            }





            Feedback

            # re: 一元多項式相加實現  回復  更多評論   

            2012-11-17 09:18 by TANGCHUNSHU
            感謝!
            久久久亚洲欧洲日产国码aⅴ| 久久国产色AV免费观看| 99久久精品免费看国产免费| 嫩草影院久久99| 婷婷综合久久中文字幕| 国产精品18久久久久久vr| 精品一久久香蕉国产线看播放 | 香蕉久久夜色精品国产尤物| 亚洲国产成人久久综合一区77 | 国产韩国精品一区二区三区久久| 亚洲国产精品人久久| 一级A毛片免费观看久久精品| 亚洲午夜久久久影院伊人| 国产福利电影一区二区三区久久久久成人精品综合 | 久久亚洲AV无码精品色午夜麻豆 | 久久精品国产欧美日韩| 无码人妻少妇久久中文字幕蜜桃 | 人妻精品久久无码区| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 伊人久久精品无码av一区| 亚洲国产精品久久久久婷婷老年| 香蕉久久夜色精品国产2020| 日本三级久久网| 日韩AV无码久久一区二区| 久久久久无码精品| 青青草原1769久久免费播放 | 日本强好片久久久久久AAA| 久久精品国产欧美日韩| a级成人毛片久久| 无码人妻久久一区二区三区免费| 欧美日韩精品久久久久| 一本伊大人香蕉久久网手机| 久久天天躁狠狠躁夜夜躁2O2O| 一个色综合久久| 亚洲伊人久久成综合人影院| 国产精品无码久久综合网| 青青草国产精品久久久久| 色综合久久久久网| 日本久久久久久中文字幕| 久久九九青青国产精品| 久久国产乱子伦精品免费强|