• <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,j,value)的形式輸出。
              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 閱讀(956) 評論(0)  編輯 收藏 引用 所屬分類: 數據結構
            久久精品国产免费| 国产精品一区二区久久精品无码| 久久国产精品一区二区| 国产成人精品综合久久久久| 久久影院亚洲一区| 久久狠狠一本精品综合网| 久久免费精品视频| 999久久久国产精品| 国产精品18久久久久久vr | 亚洲AV乱码久久精品蜜桃| 久久婷婷色综合一区二区| 欧美色综合久久久久久| 久久亚洲av无码精品浪潮| 亚洲а∨天堂久久精品| 久久综合九色综合网站| 久久香综合精品久久伊人| 久久狠狠色狠狠色综合| 国内精品久久久久影院网站| 久久久久亚洲精品中文字幕| 一本色道久久综合| 午夜人妻久久久久久久久| 久久亚洲欧美日本精品| 久久无码人妻精品一区二区三区 | 无码日韩人妻精品久久蜜桃| 99久久成人国产精品免费 | 久久久久国产精品麻豆AR影院| 日韩十八禁一区二区久久| 亚洲色婷婷综合久久| 久久久青草青青亚洲国产免观| 久久久久久久综合日本| 日韩精品久久久久久免费| 成人精品一区二区久久| 99久久精品免费看国产一区二区三区| 久久久久久久人妻无码中文字幕爆| 国产午夜电影久久| 久久福利资源国产精品999| 久久精品国产精品青草| 久久精品国产日本波多野结衣| 秋霞久久国产精品电影院| 精品综合久久久久久98| 国产真实乱对白精彩久久|