亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? 實(shí)現(xiàn)多個(gè)多項(xiàng)式的加減乘.txt

?? 清華大學(xué)版的數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)中利用鏈表編的多項(xiàng)式的加
?? TXT
字號(hào):
 


/*
* 文件名: 1_3.c(選做題)
* 實(shí)驗(yàn)環(huán)境: Turbo C 2.0
* 完成時(shí)間: 2003年2月22日
*--------------------------------------------------------------------
* 改進(jìn)說(shuō)明: 可以實(shí)現(xiàn)多個(gè)多項(xiàng)式的加法、減法、乘法,并且比書中算法更加
* 合理. 例如: 連加a+b+c+d,連減a-b-c-d,連乘a*b*c*d.
*/

#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>

#define TRUE                        1
#define FALSE                       0
#define POSITIVE                    1
#define NEGATIVE                   -1

typedef int status;
typedef struct NodeType 
{
    float fCoeff;
    int iExpon;
    struct NodeType *next;
} NodeType, *LinkType;
typedef LinkType polynomial;
typedef polynomial *PolyPointer;

status MakePolyBuff(PolyPointer *, const int);
status MakeNode(polynomial *, const float, const int);
void AppNodeToList(polynomial *, polynomial);   /* 在鏈表尾追加結(jié)點(diǎn) */
status CreatePolyn(PolyPointer, int);
status ProcStrError(const char[]); /* 檢查輸入的數(shù)據(jù) */
void SortPolyn(PolyPointer, int); /* 根據(jù)iExpon域?qū)︽湵磉M(jìn)行升序排序 */
void DestroyBuff(PolyPointer, const int);
void DestroyPolyn(polynomial);
int PolynLength(const polynomial); /* 求鏈表的長(zhǎng)度 */
void AddProcess(PolyPointer, const int, PolyPointer, const int);
void SubstractProcess(PolyPointer, const int, PolyPointer);
void MultiplyProcess(PolyPointer, const int, PolyPointer);
void PrintPolyn(const polynomial);
void MergePolynCoeff(PolyPointer, int); /* 在有序鏈表中,合并同類項(xiàng) */

int main(void)
{
    int iCounter, 
        iPolyNum; /* 多項(xiàng)式鏈表緩沖區(qū)中鏈表的個(gè)數(shù) */
    PolyPointer PolyBuff = NULL;   /* 用戶輸入的多項(xiàng)式鏈表緩沖區(qū) */
    polynomial PolyAddRes = NULL,  /* 存放連加結(jié)果鏈表 */
               PolySubRes = NULL,  /* 存放連減結(jié)果鏈表 */
               PolyMulRes = NULL;  /* 存放連乘結(jié)果鏈表 */
    char strNum[10];

    do
    {
        printf("請(qǐng)輸入需要構(gòu)造多項(xiàng)式的個(gè)數(shù),至少2個(gè): ");
        gets(strNum); 
        iPolyNum = atoi(strNum);
    } while (iPolyNum < 2);

    MakePolyBuff(&PolyBuff, iPolyNum);
    CreatePolyn(PolyBuff, iPolyNum);
    SortPolyn(PolyBuff, iPolyNum);
    MergePolynCoeff(PolyBuff, iPolyNum);
    printf("\n打印用戶輸入并整合后的多項(xiàng)式:\n");
    for (iCounter = 0; iCounter < iPolyNum; iCounter++)
    {
        printf("第%d個(gè)項(xiàng)式:\n", iCounter + 1);
        PrintPolyn(*(PolyBuff + iCounter));
    }

    AddProcess(PolyBuff, iPolyNum, &PolyAddRes, POSITIVE);
    printf("\n----------------連加結(jié)果-----------------\n");
    PrintPolyn(PolyAddRes);

    SubstractProcess(PolyBuff, iPolyNum, &PolySubRes);
    printf("\n----------------連減結(jié)果-----------------\n");
    PrintPolyn(PolySubRes);

    MultiplyProcess(PolyBuff, iPolyNum, &PolyMulRes);
    printf("\n----------------連乘結(jié)果-----------------\n");
    PrintPolyn(PolyMulRes);

    printf("\n運(yùn)行完畢!\n");
    /* 回收資源 */
    DestroyBuff(PolyBuff, iPolyNum);
    DestroyPolyn(PolyAddRes);
    DestroyPolyn(PolySubRes);
    DestroyPolyn(PolyMulRes);

    getch();
    return 0;
}

status MakePolyBuff(PolyPointer *polyBuffHead, const int iPolyNum)
{    
    int iCounter;

    *polyBuffHead = (PolyPointer)
            malloc(sizeof(polynomial) * iPolyNum);
    if (!(*polyBuffHead))
    {
        printf("錯(cuò)誤,內(nèi)存溢出!\n");
        return FALSE;
    }
    for (iCounter = 0; iCounter < iPolyNum; iCounter++)
        *(*polyBuffHead + iCounter) = NULL;

    return TRUE;
}

status CreatePolyn(PolyPointer PolyBuff, int iPolyNum)
{
    int iCounter, iExpon;
    float fCoeff;
    char strNum[100], strTemp[64], *cpCurr, *cpCurrNum;
    polynomial pNewNode = NULL, pInsPos = NULL;

    printf("\n請(qǐng)輸入構(gòu)造多項(xiàng)式的系數(shù)和指數(shù)...\n");
    printf("輸入一個(gè)多項(xiàng)式的方式為: 系數(shù), 指數(shù); ... ; 系數(shù), 指數(shù);\n例如: 3, 4; 5, 6; 7, 8;\n");
    for (iCounter = 0; iCounter < iPolyNum; iCounter++)
    {
        printf("\n請(qǐng)輸入第%d個(gè)多項(xiàng)式:\n", iCounter + 1);
        gets(strNum);
        if(!ProcStrError(strNum)) return FALSE;
        cpCurr = cpCurrNum = strNum; 
        while (*cpCurr != '\0')
        {
            if (*cpCurr == ',')
            {
                strncpy(strTemp, cpCurrNum, cpCurr - cpCurrNum);
                strTemp[cpCurr - cpCurrNum] = '\0';
                fCoeff = (float)atof(strTemp);
                cpCurrNum = cpCurr + 1;
            }
            else if (*cpCurr == ';')
            {
                strncpy(strTemp, cpCurrNum, cpCurr - cpCurrNum);
                strTemp[cpCurr - cpCurrNum] = '\0';
                iExpon = atoi(strTemp);
                MakeNode(&pNewNode, fCoeff, iExpon);
                AppNodeToList(PolyBuff + iCounter, pNewNode);
                cpCurrNum = cpCurr + 1;
            }
            cpCurr++;
        }
    }

    return TRUE;
}

status MakeNode(LinkType *pp, const float coeff, const int expon)
{
    if (!(*pp = (LinkType)malloc(sizeof(NodeType) * 1))) 
    {
        printf("Error, the memory is overflow!\n");
        return FALSE;
    }
    (*pp)->fCoeff = coeff;
    (*pp)->iExpon = expon;
    (*pp)->next = NULL;

    return TRUE;
}

void AppNodeToList(polynomial *pHead, polynomial pNewNode)
{
    static polynomial pCurrNode;

    if (!(*pHead))
        (*pHead) = pCurrNode = pNewNode;
    else
    {
        pCurrNode->next = pNewNode;
        pCurrNode = pCurrNode->next;
    }
}

void SortPolyn(PolyPointer PolyBuff, int iPolyNum)
{
    int iCounter;
    polynomial pTemp, pTempCurrNode,    /* 臨時(shí)鏈表 */
               pPrevMinExp, pCurrMinExp,/* 指向最小iExpon結(jié)點(diǎn)的指針 */
               pCurrNode, pPrevNode;

    for (iCounter = 0; iCounter < iPolyNum; iCounter++)
    {
        pTemp = NULL;
        while (*(PolyBuff + iCounter) != NULL)
        {
            pPrevNode = pPrevMinExp = pCurrMinExp = 
                            *(PolyBuff + iCounter);
            pCurrNode = (*(PolyBuff + iCounter))->next;
            while (pCurrNode != NULL)
            {
                if (pCurrMinExp->iExpon > pCurrNode->iExpon)
                {
                    pPrevMinExp = pPrevNode;
                    pCurrMinExp = pCurrNode;
                }
                pPrevNode = pCurrNode;
                pCurrNode = pCurrNode->next;
            }
            /* 將系數(shù)最小的結(jié)點(diǎn)從原鏈表中取出 */
            if (pCurrMinExp == *(PolyBuff + iCounter))
                *(PolyBuff + iCounter) = pPrevMinExp->next;
            else
                pPrevMinExp->next = pCurrMinExp->next;
            /* 將系數(shù)最小的結(jié)點(diǎn)插入升序鏈表 */
            pCurrMinExp->next = NULL;
            if (!pTemp)
                pTemp = pTempCurrNode = pCurrMinExp;
            else
            {
                pTempCurrNode->next = pCurrMinExp;
                pTempCurrNode = pTempCurrNode->next;
            }
        }

        *(PolyBuff + iCounter) = pTemp;
    }
}

void MergePolynCoeff(PolyPointer PolyBuff, int iPolyNum)
{
    int iCounter;
    float MergeCoeffRes = 0;
    polynomial TempList, ResList = NULL, pCurrNode, pPreNode,
               pNewNode = NULL;

    for (iCounter = 0; iCounter < iPolyNum; iCounter++)
    {
        pPreNode = TempList= *(PolyBuff + iCounter);
        MergeCoeffRes = pPreNode->fCoeff;
        pCurrNode = (*(PolyBuff + iCounter))->next;
        while (pCurrNode != NULL)
        {
            while ((pCurrNode != NULL) && 
                   (pCurrNode->iExpon == pPreNode->iExpon))  
            {
                MergeCoeffRes += pCurrNode->fCoeff;
                pPreNode = pCurrNode;
                pCurrNode = pCurrNode->next;
            }

            /* 在ResList中加入新結(jié)點(diǎn) */
            if (MergeCoeffRes != 0)
            {
                MakeNode(&pNewNode, MergeCoeffRes, pPreNode->iExpon);
                AppNodeToList(&ResList, pNewNode);
                MergeCoeffRes = 0;
            }

            pPreNode = pCurrNode;
        }

        DestroyPolyn(TempList);
        *(PolyBuff + iCounter) = ResList;
        ResList = NULL;
    }

}

void AddProcess(PolyPointer polyBuff, const int iPolyNum, 
                PolyPointer pResult, const int iSign)
{
    int iCounter;
    float fCoeffRes;
    polynomial pNewNode, pCurrNode_1, pCurrNode_2, 
               pDelList = NULL, /* 下次要?jiǎng)h除的中間結(jié)果鏈表 */
               pResList = NULL; /* 中間結(jié)果鏈表 */
               
    pCurrNode_1 = *(polyBuff);
    for (iCounter = 1; iCounter < iPolyNum; iCounter++)
    {
        pCurrNode_2 = *(polyBuff + iCounter);
        while (pCurrNode_1 != NULL && pCurrNode_2 != NULL)
        {
            if (pCurrNode_1->iExpon == pCurrNode_2->iExpon)
            {
                fCoeffRes = 0;
                fCoeffRes = pCurrNode_1->fCoeff + 
                            iSign * pCurrNode_2->fCoeff;
                if (fCoeffRes != 0)
                {
                    MakeNode(&pNewNode, fCoeffRes, 
                                  pCurrNode_1->iExpon);
                    AppNodeToList(&pResList, pNewNode);
                }
                pCurrNode_1 = pCurrNode_1->next;
                pCurrNode_2 = pCurrNode_2->next;
            }
            else if (pCurrNode_1->iExpon < pCurrNode_2->iExpon)
            {
                MakeNode(&pNewNode, pCurrNode_1->fCoeff, 
                                    pCurrNode_1->iExpon);
                AppNodeToList(&pResList, pNewNode);
                pCurrNode_1 = pCurrNode_1->next;
            }
            else /* 當(dāng)pCurrNode_1->iExpon > pCurrNode_2->iExpon時(shí)候 */
            {
                MakeNode(&pNewNode, iSign * pCurrNode_2->fCoeff, 
                                    pCurrNode_2->iExpon);
                AppNodeToList(&pResList, pNewNode);
                pCurrNode_2 = pCurrNode_2->next;
            }
        }
        /* 加入余下的多項(xiàng)式 */
        while (pCurrNode_1 != NULL)
        {
            MakeNode(&pNewNode, pCurrNode_1->fCoeff, 
                                pCurrNode_1->iExpon);
            AppNodeToList(&pResList, pNewNode);
            pCurrNode_1 = pCurrNode_1->next;
        }
        while (pCurrNode_2 != NULL)
        {     
            MakeNode(&pNewNode, iSign * pCurrNode_2->fCoeff, 
                                pCurrNode_2->iExpon);
            AppNodeToList(&pResList, pNewNode);
            pCurrNode_2 = pCurrNode_2->next;
        }

        if (pDelList != NULL) DestroyPolyn(pDelList);
        pCurrNode_1 = pResList;
        pDelList = pResList;
        pResList = NULL;
    }

    *pResult = pCurrNode_1;
}

void SubstractProcess(PolyPointer polyBuff, const int iPolyNum, 
                      PolyPointer pResult)
{
    AddProcess(polyBuff, iPolyNum, pResult , NEGATIVE);
}

void MultiplyProcess(PolyPointer polyBuff, const int iPolyNum, 
                     PolyPointer pResult)
{
    int iCounter = 1, jCounter = 0, iLength; /* 緩沖區(qū)的長(zhǎng)度 */
    PolyPointer pTempBuff = NULL; /* 存放中間結(jié)果的緩沖區(qū) */
    polynomial  pCurrNode_1, pCurrNode_2, pNewNode  = NULL;

    /* 初始化 */
    pCurrNode_1 = polyBuff[0]; 
    iLength = PolynLength(polyBuff[0]);
    MakePolyBuff(&pTempBuff, iLength);
    while (TRUE)
    {   
        while (pCurrNode_1 != NULL)
        {
            pCurrNode_2 = polyBuff[iCounter];
            while (pCurrNode_2 != NULL)
            {
                MakeNode(&pNewNode, 
                         pCurrNode_1->fCoeff * pCurrNode_2->fCoeff,
                         pCurrNode_1->iExpon + pCurrNode_2->iExpon);
                AppNodeToList(&pTempBuff[jCounter], pNewNode);
                pCurrNode_2 = pCurrNode_2->next;
            }
            jCounter++;
            pCurrNode_1 = pCurrNode_1->next;
        }

        /* 回收舊的中間結(jié)果 */
        if (pResult != NULL) DestroyPolyn(*pResult);
        /* 獲得新的中間結(jié)果 */
        AddProcess(pTempBuff, iLength, pResult , POSITIVE);
        DestroyBuff(pTempBuff, iLength); /* 回收存中間結(jié)果的緩沖區(qū) */
        jCounter = 0;
        if (++iCounter >= iPolyNum)
            break;
        else 
        {
            iLength = PolynLength(*pResult);
            MakePolyBuff(&pTempBuff, iLength);
            pCurrNode_1 = *pResult;
        }
   }
}

void PrintPolyn(const polynomial polyList)
{
    polynomial pCurrNode = polyList;

    printf("多項(xiàng)式的長(zhǎng)度為: %d\n", PolynLength(polyList));
    while (pCurrNode != NULL)
    {
        printf("%.2fX^%d", pCurrNode->fCoeff, pCurrNode->iExpon);
        if (pCurrNode->next != NULL)
            if (pCurrNode->next->fCoeff > 0 ) 
                printf("+");
        pCurrNode = pCurrNode->next;
    }
    printf("\n");
}

int PolynLength(const polynomial polyList)
{
    int iLength = 0;
    polynomial pCurrNode = polyList;
   
    while (pCurrNode != NULL)
    {
        pCurrNode = pCurrNode->next;
        iLength++;
    }
    return iLength;
}

void DestroyBuff(PolyPointer polyBuff, const int iPolyNum)
{
    int iCounter;

    for (iCounter = 0; iCounter < iPolyNum; iCounter++)
        DestroyPolyn(polyBuff[iCounter]);
    free(polyBuff);
}

void DestroyPolyn(polynomial polyList)
{
    polynomial pCurrNode;

    while (polyList != NULL)
    {
        pCurrNode = polyList;
        polyList = polyList->next;
        free(pCurrNode);
    }
}

status ProcStrError(const char str[])
{
    const char *cpCurr = str;

    if (!strlen(str)) 
    {
        printf("你沒(méi)有輸入數(shù)據(jù)!\n");
        return FALSE;
    }
    while (*cpCurr != '\0')
    {
        if (!(*cpCurr == ' ' || *cpCurr == ',' || *cpCurr == ';' 
            || *cpCurr == '-')
            && ('0' > *cpCurr || *cpCurr > '9')
            || (*(cpCurr + 1) == '\0' && *cpCurr != ';'))
        {
            printf("輸入數(shù)據(jù)出錯(cuò),請(qǐng)注意正確的輸入方式!\n");
            return FALSE;
        }
        cpCurr++;
    }

    return TRUE;
}
 

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品高潮呻吟久久| 一区二区三区在线影院| 色婷婷国产精品久久包臀 | www久久精品| 色综合久久久久综合体| 韩国精品久久久| 亚洲国产成人精品视频| 国产视频不卡一区| 8v天堂国产在线一区二区| 成人av在线资源网| 久久丁香综合五月国产三级网站| 亚洲精品高清视频在线观看| 国产欧美一区二区精品忘忧草| 欧美日韩精品一二三区| 成人精品国产一区二区4080| 久久爱www久久做| 亚洲国产日产av| 亚洲美女少妇撒尿| 国产欧美一区二区精品性| 欧美电视剧免费观看| 欧美日韩在线精品一区二区三区激情| 成人免费视频视频| 久久成人久久爱| 日韩精品五月天| 亚洲国产成人tv| 亚洲综合视频在线观看| 成人免费在线播放视频| 亚洲国产精品成人综合色在线婷婷| 日韩欧美国产wwwww| 欧美人妖巨大在线| 欧美日韩卡一卡二| 欧美三级日韩在线| 欧美性受xxxx| 91激情在线视频| 不卡视频在线观看| 成人高清视频免费观看| 国产成人av一区二区三区在线观看| 裸体一区二区三区| 免费成人在线视频观看| 日韩国产欧美在线播放| 日韩中文字幕麻豆| 日韩**一区毛片| 青青草原综合久久大伊人精品| 午夜伦理一区二区| 日韩精品亚洲一区| 免费精品99久久国产综合精品| 日韩成人午夜精品| 免费久久精品视频| 国内精品写真在线观看| 国产精品一卡二卡在线观看| 国产又粗又猛又爽又黄91精品| 狠狠色丁香久久婷婷综| 黄网站免费久久| 国产精品 日产精品 欧美精品| 国产激情一区二区三区四区| 不卡的电影网站| 色综合久久久久久久| 欧美亚洲日本国产| 91.xcao| 久久这里只精品最新地址| 久久久久久影视| 国产精品高潮呻吟| 一区二区日韩电影| 美女视频免费一区| 黄色成人免费在线| 99久久精品国产一区| 在线日韩一区二区| 日韩免费性生活视频播放| 久久精品亚洲乱码伦伦中文| 国产精品国产三级国产有无不卡| 亚洲黄一区二区三区| 日韩电影免费一区| 成人小视频免费观看| 91久久精品午夜一区二区| 91精品在线观看入口| 久久婷婷国产综合国色天香| 国产精品久久久久婷婷| 午夜欧美视频在线观看 | 91丨porny丨国产| 欧美日韩免费电影| xnxx国产精品| 一级中文字幕一区二区| 老司机免费视频一区二区| a亚洲天堂av| 91精品久久久久久久99蜜桃| 奇米精品一区二区三区在线观看 | 日韩一级视频免费观看在线| 久久天天做天天爱综合色| 亚洲激情网站免费观看| 久久99久久精品欧美| 91女人视频在线观看| 欧美不卡视频一区| 一区二区在线免费观看| 精品一区中文字幕| 欧美在线免费播放| 国产亚洲欧美一区在线观看| 亚洲第一在线综合网站| 国产精品69毛片高清亚洲| 欧美三级韩国三级日本三斤| 欧美极品另类videosde| 人人狠狠综合久久亚洲| 91在线porny国产在线看| 精品国产乱码久久| 亚洲国产人成综合网站| aa级大片欧美| 久久久久九九视频| 水蜜桃久久夜色精品一区的特点 | 国产精品美女久久久久av爽李琼 | 一区二区三区精品视频在线| 国产乱码一区二区三区| 欧美猛男男办公室激情| 亚洲免费毛片网站| 丁香天五香天堂综合| 日韩午夜电影av| 午夜欧美电影在线观看| 色伊人久久综合中文字幕| 国产欧美一区二区精品性色超碰| 免费日韩伦理电影| 欧美精品三级在线观看| 一区二区激情小说| 9i看片成人免费高清| 国产欧美1区2区3区| 激情综合色综合久久综合| 91麻豆精品国产91久久久资源速度| 一区二区在线免费观看| 91丝袜呻吟高潮美腿白嫩在线观看| 国产免费成人在线视频| 国产麻豆视频精品| 欧美不卡激情三级在线观看| 日韩电影在线观看网站| 欧美喷水一区二区| 午夜国产精品一区| 欧美日韩一区二区不卡| 亚洲午夜在线观看视频在线| 91国产视频在线观看| 亚洲人成网站精品片在线观看| 成人一区二区三区视频在线观看| 久久久精品tv| 国产成人免费视| 国产欧美一区视频| 成人国产精品免费观看动漫| 国产精品国产自产拍在线| 成人高清免费观看| 国产精品看片你懂得| 成人av午夜电影| 国产精品国产自产拍高清av王其 | 国产精品毛片无遮挡高清| 成人免费av在线| 国产精品福利电影一区二区三区四区| 成人国产电影网| 亚洲日本一区二区三区| 91丨porny丨最新| 亚洲影院在线观看| 欧美精品久久一区| 久久福利资源站| 欧美国产综合一区二区| 91一区二区在线| 亚洲综合区在线| 9191精品国产综合久久久久久 | 精品一区二区国语对白| 精品国产第一区二区三区观看体验| 国产一区二区三区国产| 国产精品久久久久一区| 在线观看日韩毛片| 青草av.久久免费一区| 久久女同精品一区二区| av动漫一区二区| 五月婷婷久久综合| 精品国产91乱码一区二区三区| 国产成人精品免费视频网站| 亚洲精品国产精华液| 日韩精品一区二区在线| 成人一级视频在线观看| 亚洲福利国产精品| 久久人人爽爽爽人久久久| 日本久久电影网| 久久国产夜色精品鲁鲁99| 成人欧美一区二区三区小说| 在线观看91av| 粉嫩一区二区三区性色av| 亚洲午夜久久久久久久久电影院| 欧美成人一级视频| 99re6这里只有精品视频在线观看| 亚洲1区2区3区4区| 日本一区二区免费在线观看视频 | 激情综合五月天| 樱花草国产18久久久久| 欧美哺乳videos| 在线精品视频免费播放| 国产一区二区免费在线| 亚洲资源中文字幕| 欧美国产在线观看| 4438x成人网最大色成网站| 大桥未久av一区二区三区中文| 亚洲国产综合91精品麻豆| 国产无人区一区二区三区| 欧美日韩一区二区在线观看| 成人高清在线视频| 久久99精品国产.久久久久久| 一区二区三区资源|