• <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>

            ADT多項式(C實現)

            初學數據結構,感覺還是應該多練習才好,于是寫了一個“ADT多項式”的實現,同時也當作一個學習,代碼如下,gcc編譯通過,由于寫的倉促,注釋較少,有什么問題可以給小弟留言。


            #include<stdio.h>
            #define MAX_TERMS 100


            typedef struct{
                float coef;        /*系數*/
                int expon;        /*指數*/
            } polynomial;

            polynomial terms[MAX_TERMS-1] = {2,1000,1,0,1,4,10,3,3,2,1,0},temp[MAX_TERMS];
            int avail = 0;


            void padd(int,int,int,int,int*,int*);
            void attach(float,int);
            int compare(int,int);


            int compare(int a,int b)
            {
                if(a > b)
                    return 1;
                else if(a == b)
                            return 0;
                        else
                            return -1;
            }


            void padd(int starta,int finisha,int startb,int finishb,int* startd,int* finishd)
            {
                float coefficient;
                *startd = avail;
                while(starta <= finisha && startb <= finishb)
                    switch(compare(terms[starta].expon,terms[startb].expon))
                    {
                        case -1 :
                                    attach(terms[startb].coef,terms[startb].expon);
                                    startb++;
                                    break;
                        case 0 :
                                    coefficient = terms[starta].coef + terms[startb].coef;
                                    if(coefficient)
                                        attach(coefficient,terms[starta].expon);
                                    starta++;
                                    startb++;
                                    break;
                        case 1 :
                                    attach(terms[starta].coef,terms[starta].expon);
                                    starta++;
                                    break;
                    }
                for( ; starta <= finisha; starta++)
                    attach(terms[starta].coef,terms[starta].expon);
                for( ; startb <= finishb; startb++)
                    attach(terms[startb].coef,terms[finishb].expon);
                *finishd = avail;
            }


            void attach(float coefficient,int exponent)
            {
                if(avail >= MAX_TERMS)
                {
                    printf("Too many terms in the polynomial");
                    return;
                }
                temp[avail].coef = coefficient;
                temp[avail].expon = exponent;
                avail++;
            }


            int  main()
            {
                int i,starta = 0,finisha = 1,startb = 2,finishb = 5,startd,finishd;
                padd(starta,finisha,startb,finishb,&startd,&finishd);
                printf("polynomial:\n");
                for(i = 0;i < finishd;++i)
                {
                    printf("coef %f  expon %d \n",temp[i].coef,temp[i].expon);
                }
                return 0;
            }


            posted on 2007-04-15 19:07 honker 閱讀(752) 評論(0)  編輯 收藏 引用

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導航

            常用鏈接

            留言簿(3)

            隨筆分類(10)

            隨筆檔案(14)

            相冊

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产精品嫩草影院久久| 99久久国产综合精品麻豆| 久久久久人妻精品一区三寸蜜桃| 国产精品久久久天天影视香蕉| 国产亚洲婷婷香蕉久久精品| 久久精品亚洲精品国产欧美| 7777精品久久久大香线蕉| 精品国产91久久久久久久| 久久午夜免费视频| 国产V综合V亚洲欧美久久| 欧美国产成人久久精品| 国产精品久久精品| 99久久无色码中文字幕人妻| 办公室久久精品| 好属妞这里只有精品久久| 欧美亚洲另类久久综合婷婷| 久久精品www| 久久99亚洲网美利坚合众国| 午夜精品久久久久久久无码| 久久99精品国产一区二区三区| 亚洲午夜福利精品久久| 国产精品日韩深夜福利久久| 99久久精品国产高清一区二区 | 久久精品一区二区三区不卡| 亚洲精品NV久久久久久久久久 | 久久九九精品99国产精品| 久久久久香蕉视频| 国内精品欧美久久精品| 精品久久一区二区三区| 精品亚洲综合久久中文字幕| 久久99精品久久久久婷婷| 亚洲成色www久久网站夜月| 一本久久a久久精品综合香蕉| 99久久精品国产综合一区| 亚洲天堂久久精品| 国产一区二区精品久久凹凸| 大香网伊人久久综合网2020| 国产精品熟女福利久久AV| 国产高潮久久免费观看| 久久久久久噜噜精品免费直播| 久久久久综合中文字幕|