• <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多項(xiàng)式(C實(shí)現(xiàn))

            初學(xué)數(shù)據(jù)結(jié)構(gòu),感覺(jué)還是應(yīng)該多練習(xí)才好,于是寫了一個(gè)“ADT多項(xiàng)式”的實(shí)現(xiàn),同時(shí)也當(dāng)作一個(gè)學(xué)習(xí),代碼如下,gcc編譯通過(guò),由于寫的倉(cāng)促,注釋較少,有什么問(wèn)題可以給小弟留言。


            #include<stdio.h>
            #define MAX_TERMS 100


            typedef struct{
                float coef;        /*系數(shù)*/
                int expon;        /*指數(shù)*/
            } 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 閱讀(764) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            <2007年4月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導(dǎo)航

            常用鏈接

            留言簿(3)

            隨筆分類(10)

            隨筆檔案(14)

            相冊(cè)

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            中文字幕久久久久人妻| 久久亚洲国产成人精品性色| AAA级久久久精品无码区| 久久人人爽人人澡人人高潮AV | 人妻精品久久久久中文字幕一冢本| 伊人久久大香线蕉AV色婷婷色| 久久国产成人精品麻豆| 欧美亚洲国产精品久久久久| 狠色狠色狠狠色综合久久| 人妻无码αv中文字幕久久琪琪布 人妻无码精品久久亚瑟影视 | 久久国产亚洲精品| 久久精品成人国产午夜| 国产精品99久久久精品无码| 国产成人久久精品麻豆一区| 无码人妻精品一区二区三区久久 | 亚洲国产天堂久久综合| 一本大道加勒比久久综合| 精品久久久中文字幕人妻| 日日狠狠久久偷偷色综合免费 | 久久99精品久久久久久| 国产色综合久久无码有码| 免费精品久久久久久中文字幕| 久久精品国产99国产电影网 | 久久综合狠狠综合久久综合88 | 伊人久久精品线影院| 亚洲欧美日韩久久精品第一区| 久久国产精品无码网站| 国产精品99久久久久久董美香| 久久电影网2021| 99久久久国产精品免费无卡顿 | 久久亚洲欧洲国产综合| 久久人人爽人人精品视频| 久久久久女教师免费一区| 久久国产精品波多野结衣AV| 91精品日韩人妻无码久久不卡| 久久久精品一区二区三区| 久久福利青草精品资源站| 国产精品女同一区二区久久| 久久有码中文字幕| 久久久久久久免费视频| 人妻无码精品久久亚瑟影视 |