• <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轉置的程序算法,轉置結果為另一個十字鏈表,并將該轉置矩陣以三元組(ijvalue)的形式輸出。
              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)  編輯 收藏 引用 所屬分類: 數據結構
            欧洲国产伦久久久久久久| 久久只有这精品99| 91精品日韩人妻无码久久不卡 | 久久久国产精品网站| 国产精自产拍久久久久久蜜 | 成人午夜精品无码区久久| 性欧美大战久久久久久久久 | 久久久久国产一区二区| 国产成人精品三上悠亚久久| 久久最新精品国产| 亚洲精品高清国产一线久久| 国产精品美女久久久久av爽| 婷婷五月深深久久精品| 精品久久久久久无码免费| 欧美噜噜久久久XXX| 久久99精品久久久久久野外| 久久久久久九九99精品| 要久久爱在线免费观看| 99久久精品国产综合一区| 国产美女亚洲精品久久久综合| 精品水蜜桃久久久久久久| 69久久夜色精品国产69| 精品国产99久久久久久麻豆| 久久久久久毛片免费看 | 超级碰久久免费公开视频| 一本一本久久A久久综合精品| 国产精品无码久久久久| 欧美亚洲另类久久综合| 精品国产一区二区三区久久久狼| 2021最新久久久视精品爱| 久久久久黑人强伦姧人妻| 精品999久久久久久中文字幕| 久久综合香蕉国产蜜臀AV| 东方aⅴ免费观看久久av| 久久亚洲日韩看片无码| 波多野结衣久久| 偷偷做久久久久网站| 久久人做人爽一区二区三区| 亚洲午夜久久久| 久久久久人妻一区二区三区| 97精品国产97久久久久久免费 |