• <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++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            歸并兩個線性表得到新的線性表

            Posted on 2012-08-21 21:51 hoshelly 閱讀(306) 評論(0)  編輯 收藏 引用 所屬分類: DS && Algorithm
            #include<stdio.h>
            #include<stdlib.h>
            #define LIST_INIT_SIZE 100
            #define LISTINCREMENT 10
            #define OK 1
            #define ERROR 0
            #define OVERFLOW -1
            typedef int ElemType;
            typedef int Status;
            typedef struct {
                ElemType *elem; //存儲空間基址
                int length; //當前的線性表長度
                int listsize; //當前分配的存儲容量
            }SqList;

            //初始化線性表
            Status InitList_Sq(SqList *L) //用線性表的指針操作
            {
                (*L).elem = (ElemType *)malloc(LIST_INIT_SIZE*sizeof(ElemType));
                if(!(*L).elem) exit(OVERFLOW);
                (*L).length=0;
                (*L).listsize=LIST_INIT_SIZE;
                return OK;
            }
            int ListLength(SqList L)
            {
                return L.length;
            }

            Status GetElem(SqList L,int i,ElemType *e)
            {
                if(i<1 || i>L.length)
                    exit(ERROR);
                *e=*(L.elem+i-1);
                return OK;
            }

            Status ListInsert(SqList *L,int i,ElemType e)
            {
                ElemType *newbase,*p,*q;
                if(i<1 || i>(*L).length+1)
                    return ERROR;
                if((*L).length >= (*L).listsize)
                {
                    newbase=(ElemType *)realloc((*L).elem,((*L).listsize+LISTINCREMENT)*sizeof(ElemType));
                    if(!newbase) exit(OVERFLOW);
                    (*L).elem=newbase;
                    (*L).listsize +=LISTINCREMENT;
                }
                q=(*L).elem+i-1; //插入位置
                for(p=(*L).elem+(*L).length-1;p>=q;--p)
                    *(p+1)=*p;
                *q=e;
                ++(*L).length;
                return OK;
            }

            Status Visit(ElemType *c)
            {
                printf("%d ",*c);
                return OK;
            }

            Status ListTraverse(SqList L)
            {
                int i;
                for(i=0;i<L.length;i++)
                    Visit(L.elem+i);
                printf("\n");
                return OK;
            }


            void MergeList(SqList La,SqList Lb,SqList *Lc) //歸并線性表La和Lb得到新的線性表Lc,Lc的數據元素安置遞減排列
            {
                int i=1,j=1,k=0;
                int La_len,Lb_len;
                ElemType ai,bj;
                InitList_Sq(Lc);
                La_len=ListLength(La);
                Lb_len=ListLength(Lb);
                while((i<=La_len) && (j<=Lb_len)) //如果表La和表Lb都非空
                {
                    GetElem(La,i,&ai);
                    GetElem(Lb,j,&bj);
                    if(ai<=bj)
                    {
                        ListInsert(Lc,++k,ai); ++i;
                    }
                    else
                    {
                        ListInsert(Lc,++k,bj); ++j;
                    }
                }

                while(i<=La_len)  //如果只有La非空
                {
                    GetElem(La,i++,&ai);
                    ListInsert(Lc,++k,ai);
                }

                while(j<=Lb_len)
                {
                    GetElem(Lb,j++,&bj);
                    ListInsert(Lc,++k,bj);
                }
            }
            int main()
            {
                SqList La,Lb,Lc;
                int j,a[4]={3,5,8,11},b[7]={2,6,8,9,11,15,20};
                InitList_Sq(&La);
                for(j=1;j<=4;j++)
                    ListInsert(&La,j,a[j-1]);
                printf("print La: \n");
                ListTraverse(La);
                
                InitList_Sq(&Lb);
                for(j=1;j<=7;j++)
                    ListInsert(&Lb,j,b[j-1]);
                printf("print Lb: \n");
                ListTraverse(Lb);

                MergeList(La,Lb,&Lc);

                printf("print Lc: \n");
                ListTraverse(Lc);

                return 0;
            }
            久久精品嫩草影院| 99久久精品毛片免费播放| 青青草国产精品久久久久| 无码人妻精品一区二区三区久久久| 久久久精品无码专区不卡| 91秦先生久久久久久久| 久久青青草原综合伊人| 国产亚洲色婷婷久久99精品| 色婷婷久久综合中文久久蜜桃av| 精产国品久久一二三产区区别 | 精品久久久久久亚洲| 欧洲精品久久久av无码电影| 99精品久久久久久久婷婷| 久久99热这里只有精品国产| 久久精品国产亚洲AV忘忧草18| 久久天天躁夜夜躁狠狠躁2022| 精品久久亚洲中文无码| 亚洲成色WWW久久网站| 婷婷久久香蕉五月综合加勒比| 久久久亚洲欧洲日产国码二区| 国产精品国色综合久久| 亚洲狠狠久久综合一区77777| 久久精品国产久精国产| 国产精品日韩深夜福利久久| 久久精品国产色蜜蜜麻豆| 久久综合色区| 日韩人妻无码一区二区三区久久99| 亚洲伊人久久大香线蕉综合图片| 日本欧美久久久久免费播放网| 久久99毛片免费观看不卡| a级毛片无码兔费真人久久| 久久精品国产精品亚洲| 久久乐国产综合亚洲精品| 国产一区二区精品久久岳| 久久午夜无码鲁丝片午夜精品| 亚洲美日韩Av中文字幕无码久久久妻妇| 亚洲精品久久久www| 狼狼综合久久久久综合网| 一本大道久久a久久精品综合| 欧美粉嫩小泬久久久久久久 | 狠狠色丁香久久综合婷婷|