• <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 閱讀(971) 評論(0)  編輯 收藏 引用 所屬分類: 數據結構
            国产毛片久久久久久国产毛片| 久久久久久久免费视频| 中文无码久久精品| 色综合久久天天综合| 香港aa三级久久三级老师2021国产三级精品三级在| 国产免费福利体检区久久| 午夜精品久久久久成人| 久久综合欧美成人| 久久久久久久波多野结衣高潮| 久久精品国产亚洲沈樵| 97精品伊人久久大香线蕉| 国产精品久久久久乳精品爆 | 欧美粉嫩小泬久久久久久久| 国产成人精品综合久久久久| 国产精品狼人久久久久影院| av午夜福利一片免费看久久| 一级做a爰片久久毛片毛片| 天天爽天天爽天天片a久久网| 色播久久人人爽人人爽人人片AV| 国产免费久久精品丫丫| 久久久精品免费国产四虎| 久久久无码一区二区三区| 精品国产日韩久久亚洲| 午夜精品久久久内射近拍高清| www亚洲欲色成人久久精品| 久久电影网2021| 国产成人精品久久免费动漫| 久久久久亚洲精品无码蜜桃| 婷婷伊人久久大香线蕉AV | 久久这里只有精品首页| 久久超碰97人人做人人爱| 丁香色欲久久久久久综合网| 中文字幕无码免费久久| 麻豆av久久av盛宴av| 亚洲AV无码久久精品成人| 色婷婷综合久久久久中文| 久久99国内精品自在现线| 久久精品国内一区二区三区| 久久婷婷久久一区二区三区| 91精品国产高清久久久久久91| 99久久精品国产毛片|