亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
亚洲一区二区在线视频| 国产成人精品在线看| 成人精品鲁一区一区二区| 欧美视频在线一区| |精品福利一区二区三区| 久久er99热精品一区二区| 欧美午夜电影网| 日韩一区日韩二区| 丁香五精品蜜臀久久久久99网站| 91精品国产综合久久久久久漫画| 中文字幕亚洲成人| 丁香婷婷综合五月| 精品成人私密视频| 久久国产精品色| 日韩一区二区影院| 美女在线一区二区| 91精品在线麻豆| 日韩国产精品大片| 欧美日本国产一区| 午夜视频一区二区| 欧美二区乱c少妇| 爽好久久久欧美精品| 欧美日韩视频在线一区二区| 一区av在线播放| 在线免费视频一区二区| 亚洲精品免费电影| 欧美在线色视频| 亚洲综合网站在线观看| 欧洲色大大久久| 亚洲国产综合视频在线观看| 日本精品视频一区二区三区| 亚洲黄色av一区| 欧美亚洲国产一区二区三区 | 欧美成人一区二区三区| 久久超级碰视频| 国产亚洲污的网站| av不卡免费电影| 亚洲国产视频一区二区| 欧美日韩第一区日日骚| 日本亚洲视频在线| 久久久国产一区二区三区四区小说| 卡一卡二国产精品| 国产日韩欧美精品在线| 成人h版在线观看| 亚洲综合一区在线| 欧美一二三在线| 国产精品一区免费视频| 中文字幕一区av| 欧美老女人第四色| 国产乱理伦片在线观看夜一区| 欧美国产国产综合| 在线观看免费一区| 国产在线播精品第三| 国产精品麻豆99久久久久久| 91福利视频在线| 久久99精品国产91久久来源| 国产精品卡一卡二| 欧美精品精品一区| www.亚洲人| 美女一区二区视频| 亚洲毛片av在线| 精品少妇一区二区三区日产乱码 | 激情文学综合网| 中文字幕永久在线不卡| 91.麻豆视频| 成人污视频在线观看| 亚洲成人动漫精品| 国产免费观看久久| 欧美日产国产精品| 国产精品夜夜爽| 亚洲国产成人tv| 中文字幕国产一区| 日韩一区二区三区免费看 | 91麻豆精东视频| 日本伊人色综合网| 亚洲视频小说图片| 精品国产乱码久久久久久久久| 91蝌蚪porny九色| 狠狠色综合播放一区二区| 一区二区三区国产精品| 欧美精品一区二区三区久久久 | www.日本不卡| 国产最新精品精品你懂的| 亚洲综合视频在线| 中文天堂在线一区| 日韩一区二区在线观看视频播放| 91欧美激情一区二区三区成人| 九色综合狠狠综合久久| 天堂一区二区在线| 亚洲电影你懂得| 亚洲欧美视频在线观看视频| 亚洲国产精品成人综合色在线婷婷| 欧美理论在线播放| 欧美色男人天堂| 色婷婷综合五月| www.66久久| hitomi一区二区三区精品| 国产一区二区导航在线播放| 日本女优在线视频一区二区| 亚洲h精品动漫在线观看| 一区二区三区精品在线| 国产精品美女久久久久久久久| 2021久久国产精品不只是精品| 欧美精选一区二区| 欧美丰满高潮xxxx喷水动漫| 欧美日韩免费一区二区三区视频| 暴力调教一区二区三区| av在线综合网| 91香蕉视频污| 日本久久一区二区| 欧美性猛交xxxxxxxx| 欧美在线三级电影| 欧美三级乱人伦电影| 欧美日韩精品久久久| 欧美日韩一区二区在线视频| 欧美色爱综合网| 欧美日韩dvd在线观看| 欧美日韩国产免费| 91精品国产高清一区二区三区| 欧美日本一区二区三区四区| 4438x成人网最大色成网站| 91精品久久久久久久久99蜜臂| 欧美一卡在线观看| 久久奇米777| 国产精品卡一卡二| 亚洲最色的网站| 日韩高清中文字幕一区| 国产美女av一区二区三区| 成人精品高清在线| 在线亚洲精品福利网址导航| 欧美日韩另类一区| 欧美精品一区二区三区蜜臀| 国产精品免费视频一区| 亚洲精品免费电影| 麻豆免费精品视频| 高潮精品一区videoshd| 在线观看国产日韩| 日韩免费在线观看| 中文字幕五月欧美| 天堂在线亚洲视频| 岛国一区二区在线观看| 色婷婷精品大视频在线蜜桃视频 | 欧美大片在线观看一区二区| 国产午夜精品一区二区| 中文字幕日韩av资源站| 蜜臀av国产精品久久久久| 成人av在线播放网址| 欧美日韩国产一级二级| 久久亚洲欧美国产精品乐播| 亚洲精品高清在线| 国产在线看一区| 欧美午夜精品久久久久久超碰| 2024国产精品| 亚洲一区二区三区四区在线| 国内精品不卡在线| 在线国产电影不卡| 久久精品网站免费观看| 日韩精品视频网站| www.色综合.com| 精品91自产拍在线观看一区| 亚洲免费观看高清完整版在线观看 | 中文字幕亚洲欧美在线不卡| 日本视频免费一区| 91国产视频在线观看| 国产日韩三级在线| 男女性色大片免费观看一区二区 | 欧美日韩国产高清一区二区 | 欧美日韩久久一区| 国产精品免费视频观看| 久久成人免费网站| 欧美日韩精品免费| 亚洲久本草在线中文字幕| 韩国av一区二区| 欧美xxxx在线观看| 亚洲成av人影院| 欧洲精品视频在线观看| 国产精品女主播在线观看| 九一久久久久久| 欧美一级欧美三级| 天堂av在线一区| 欧美日韩视频一区二区| 亚洲午夜久久久| 一本到高清视频免费精品| 国产精品久久久久7777按摩| 国产成人午夜99999| 日韩精品一区二区在线| 久久精品久久综合| 欧美一区二区精品久久911| 午夜视频一区二区| 欧美放荡的少妇| 日韩电影免费一区| 日韩一区二区视频| 激情小说欧美图片| 久久午夜老司机| 国产精品18久久久久久久网站| 日韩欧美一区二区久久婷婷| 肉色丝袜一区二区| 日韩欧美二区三区| 国产真实精品久久二三区| 精品国产乱码久久久久久夜甘婷婷|