• <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++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
            2.3x4+3.2x3+2x2+1.2x與5.6x5-2.3x4+3.4x3
            相加結(jié)果為:5.6x5+6.6x3 +2x2+1.2x
            首先考慮存儲(chǔ)結(jié)構(gòu),多項(xiàng)式中的每一項(xiàng)包括“系數(shù)”和“指數(shù)”兩項(xiàng),且相加運(yùn)算可能會(huì)改變系數(shù)和指數(shù),故應(yīng)采用鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)。在一個(gè)單鏈表結(jié)點(diǎn)中,存儲(chǔ)多項(xiàng)式一項(xiàng)的系數(shù)和指數(shù)。其次,考慮多項(xiàng)式的運(yùn)算規(guī)則:對(duì)于兩個(gè)一元多項(xiàng)式中所有指數(shù)相同的項(xiàng),對(duì)應(yīng)系數(shù)相加,若和不為0,則構(gòu)成“和多項(xiàng)式”中的一項(xiàng);對(duì)于兩個(gè)一元多項(xiàng)式中所有指數(shù)不同的項(xiàng),則分別復(fù)抄到“和多項(xiàng)式”中去。


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

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

            typedef  LinkList  polynomial;    //帶頭結(jié)點(diǎn)的單鏈表表示多項(xiàng)式

            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;
            }

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

            //多項(xiàng)式相加得到新的多項(xiàng)式
            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)){    //比較兩個(gè)多項(xiàng)式的指數(shù)
                    case -1:        //多項(xiàng)式pa當(dāng)前結(jié)點(diǎn)的指數(shù)值小
                        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:        //兩個(gè)多項(xiàng)式指數(shù)值相等
                        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:        //多項(xiàng)式pb當(dāng)前結(jié)點(diǎn)的指數(shù)值小
                        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剩余結(jié)點(diǎn)
            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剩余結(jié)點(diǎn)
            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;
            }    
            //輸出多項(xiàng)式單鏈表
            void PrintPolyn(polynomial p){
                polynomial s;
                s=p->link;
                while(s){
                //輸出系數(shù)和指數(shù)
                cout<<s->info.coef<<"("<<s->info.expn<<")";
                s=s->link;
            }
            cout<<endl;
            }
                void main(){
                int m,n;
                polynomial p,q;
                cout<<"請(qǐng)輸入多項(xiàng)式pa的項(xiàng)數(shù):";
                cin>>m;
                CreatPolyn(p,m);
                cout<<"請(qǐng)輸入多項(xiàng)式pb的項(xiàng)數(shù):";
                cin>>n;
                CreatPolyn(q,n);
                PrintPolyn(p);
                PrintPolyn(q);
                PrintPolyn(AddPolyn(p,q));
            }





            Feedback

            # re: 一元多項(xiàng)式相加實(shí)現(xiàn)  回復(fù)  更多評(píng)論   

            2012-11-17 09:18 by TANGCHUNSHU
            感謝!
            久久久久国产一级毛片高清板| 国产999精品久久久久久| 日本精品一区二区久久久| 久久AⅤ人妻少妇嫩草影院| 久久久久亚洲AV成人网人人网站| 久久久久亚洲AV成人网| 一本色道久久综合狠狠躁篇| 新狼窝色AV性久久久久久| 狠狠狠色丁香婷婷综合久久五月| 久久国产精品免费一区二区三区| 久久久久久久久久久免费精品| 久久久久久国产精品无码下载| 久久精品午夜一区二区福利| 久久婷婷色综合一区二区| 91精品国产乱码久久久久久 | 国产精品一区二区久久精品无码| 伊人色综合九久久天天蜜桃| 狠狠干狠狠久久| 亚洲欧美伊人久久综合一区二区| 国产精品成人99久久久久| 久久婷婷国产剧情内射白浆| 久久国产乱子伦精品免费强| 久久久久亚洲AV无码专区首JN| 国产精品久久久久影视不卡| 综合久久给合久久狠狠狠97色| 久久精品这里热有精品| 亚洲国产一成人久久精品 | 一本色道久久88综合日韩精品| 韩国无遮挡三级久久| 精品永久久福利一区二区| 精品久久久久成人码免费动漫 | 99久久er这里只有精品18| 国产A三级久久精品| 伊人久久成人成综合网222| 国产精品成人无码久久久久久| 国内精品久久久久久久97牛牛| 亚洲国产成人久久综合碰| 久久国产综合精品五月天| 国产精品热久久毛片| 久久99精品久久久大学生| 久久久久久午夜精品|