• <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 - 100,  comments - 15,  trackbacks - 0
            編寫將十字鏈表表示的矩陣A轉置的程序算法,轉置結果為另一個十字鏈表,并將該轉置矩陣以三元組(i,jvalue)的形式輸出。
              1#include<iostream>
              2using namespace std;
              3#define MAX 100
              4
              5struct Node
              6{
              7    int i,j;    //
              8    int e;    //element
              9    Node *right,*down;
             10}
            ;
             11
             12struct CrossList
             13{
             14    int r,c,nz;
             15    Node **rhead,**chead;
             16}
            ;
             17
             18
             19int row,rowt;
             20int col,colt;
             21int nz;    //not zore
             22CrossList M,MT;
             23
             24void creatcrosslist(CrossList & M,int row,int col)
             25{
             26    int i,j,e;
             27    Node *p,*q;
             28
             29    M.r=row; M.c=col;
             30
             31    if(M.rhead==NULL)
             32        M.rhead=new Node*[M.r+1];
             33    for(i=1;i<=row;i++)
             34        M.rhead[i]=NULL;
             35
             36    if(M.chead==NULL)
             37        M.chead=new Node*[M.c+1];
             38    for(j=1;j<=col;j++)
             39        M.chead[j]=NULL;
             40
             41    for(i=1;i<=M.r;i++)
             42        for(j=1;j<=M.c;j++)
             43        {
             44            scanf("%d",&e);
             45            if(e)
             46            {
             47                nz++;
             48                p=new Node;
             49                p->i=i;
             50                p->j=j;
             51                p->e=e;
             52                if(M.rhead[i]==NULL || M.rhead[i]->> j)
             53                {
             54                    p->right=M.rhead[i];
             55                    M.rhead[i]=p;
             56                }
            else{
             57                    for(q=M.rhead[i];q->right!=NULL && q->right->< j;q=q->right);
             58                    p->right=q->right;
             59                    q->right=p;
             60                }
            //end if
             61                if(M.chead[j]==NULL || M.chead[j]->> i)
             62                {
             63                    p->down=M.chead[j];
             64                    M.chead[j]=p;
             65                }
            else{
             66                    for(q=M.chead[j];q->down!=NULL && q->down->< i;q=q->down);
             67                    p->down=q->down;
             68                    q->down=p;
             69                }
            //end if
             70            }
            //end if
             71        }

             72    M.nz=nz;//not zero
             73
             74}
            //end creat
             75
             76void T()
             77{
             78    Node *p,*q,*s;
             79    int i,j;
             80
             81    MT.r=rowt; MT.c=colt;MT.nz=nz;
             82
             83    if(MT.rhead==NULL)
             84        MT.rhead=new Node*[MT.r+1];
             85    for(i=1;i<=row;i++)
             86        MT.rhead[i]=NULL;
             87
             88    if(MT.chead==NULL)
             89        MT.chead=new Node*[MT.c+1];
             90    for(j=1;j<=col;j++)
             91        MT.chead[j]=NULL;
             92
             93    for(i=1;i<=M.r;i++)
             94        for(s=M.rhead[i];s!=NULL;s=s->right)
             95        {
             96            p=new Node;
             97            p->i=s->j;
             98            p->j=s->i;
             99            p->e=s->e;
            100            if(MT.rhead[p->i]==NULL || MT.rhead[p->i]->> p->j)
            101            {
            102                p->right=MT.rhead[p->i];
            103                MT.rhead[p->i]=p;
            104            }
            else{
            105                for(q=MT.rhead[p->i];q->right!=NULL && q->right->< p->j;q=q->right);
            106                p->right=q->right;
            107                q->right=p;
            108            }
            //end if
            109
            110            if(MT.chead[p->j]==NULL || MT.chead[p->j]->> p->i)
            111            {
            112                p->down=MT.chead[p->j];
            113                MT.chead[p->j]=p;
            114            }
            else{
            115                for(q=MT.chead[p->j];q->down!=NULL && q->down->< p->i;q=q->down);
            116                p->down=q->down;
            117                q->down=p;
            118            }
            //end if
            119        }

            120}

            121
            122void travelcrosslist(CrossList M)
            123{
            124    Node *p;
            125    int i;
            126    for(i=1;i<=M.r;i++)
            127        for(p=M.rhead[i];p!=NULL;p=p->right)
            128            printf("(%d,%d,%d)\n",p->i,p->j,p->e);
            129}

            130
            131void free(CrossList &M)
            132{
            133    Node *p,*q;
            134    int i;
            135    for(i=1;i<=M.r;i++)
            136        for(p=M.rhead[i];p!=NULL;)
            137        {
            138            q=p->right;
            139            delete p;
            140            p=q;
            141        }

            142    M.r=0;
            143    M.c=0;
            144    M.nz=0;
            145    delete []M.rhead;
            146    M.rhead=NULL;
            147    delete []M.chead;
            148    M.chead=NULL;
            149}

            150
            151int main()
            152{
            153    scanf("%d%d",&row,&col);
            154    rowt=col;
            155    colt=row;
            156
            157    creatcrosslist(M,row,col);
            158    printf("M:\n");
            159    travelcrosslist(M);
            160
            161    T();//轉置
            162    printf("MT:\n");
            163    travelcrosslist(MT); //遍歷輸出
            164
            165    free(M); //delete M
            166    free(MT);//delete MT
            167    return 0;
            168}
            posted on 2009-05-13 17:06 wyiu 閱讀(960) 評論(0)  編輯 收藏 引用 所屬分類: 數據結構
            伊人色综合久久天天人守人婷 | 亚洲国产成人久久一区WWW| 精品久久久久久无码国产| 亚洲欧美成人久久综合中文网| 亚洲精品成人久久久| 亚洲国产欧美国产综合久久| 久久国产精品成人免费| 亚洲另类欧美综合久久图片区| 精品久久久久久中文字幕人妻最新 | 久久99精品久久久大学生| 久久丫精品国产亚洲av不卡 | 久久久久九国产精品| 亚洲av日韩精品久久久久久a| 成人国内精品久久久久影院VR| 久久久久久久精品成人热色戒 | 色99久久久久高潮综合影院| 国产美女亚洲精品久久久综合| 国内精品久久久久久久影视麻豆| 亚洲精品美女久久久久99| 91麻精品国产91久久久久| 亚洲狠狠婷婷综合久久蜜芽| 国产精品久久久久久久午夜片| 色欲久久久天天天综合网| 国产精品激情综合久久| 久久99国产精品二区不卡| 香港aa三级久久三级老师2021国产三级精品三级在 | 欧美性猛交xxxx免费看久久久| 久久人妻少妇嫩草AV无码专区| 亚洲乱码日产精品a级毛片久久 | 久久久女人与动物群交毛片| 热RE99久久精品国产66热| 伊人久久大香线蕉影院95| 91视频国产91久久久| 无码专区久久综合久中文字幕 | 久久国产免费直播| 尹人香蕉久久99天天拍| 久久久久久久久久久免费精品| 国产高清美女一级a毛片久久w| 久久福利青草精品资源站免费| 久久99精品国产99久久| 久久午夜电影网|