• <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 閱讀(956) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結構
            波多野结衣久久| 国产精品99久久精品| 久久久久精品国产亚洲AV无码| 欧美牲交A欧牲交aⅴ久久 | 亚洲国产精品无码久久久秋霞2 | 欧美一区二区三区久久综 | 精品久久久久久成人AV| 久久久精品国产Sm最大网站| 久久久久se色偷偷亚洲精品av| 久久99国产精品二区不卡| 久久久久99这里有精品10| 久久99国产精一区二区三区| 久久精品国产久精国产果冻传媒 | 办公室久久精品| 亚洲国产精品无码久久98| 久久这里有精品视频| 久久这里只有精品久久| 亚洲国产一成人久久精品| 国产女人aaa级久久久级| 国内精品久久久久久久97牛牛| 色99久久久久高潮综合影院| 国产激情久久久久影院老熟女免费 | 国内精品伊人久久久久777| 久久99精品九九九久久婷婷| 69SEX久久精品国产麻豆| 久久人妻少妇嫩草AV蜜桃| 色婷婷综合久久久久中文字幕| 精品久久久久中文字幕一区| 99久久这里只有精品| 精品久久久久久成人AV| 久久精品欧美日韩精品| 久久香综合精品久久伊人| 久久精品国产精品亚洲精品 | 久久久久久狠狠丁香| 久久亚洲AV成人无码电影| 国产精品美女久久久久久2018| 中文字幕热久久久久久久| 国内精品综合久久久40p| 日韩精品无码久久久久久| 奇米影视7777久久精品| 久久大香香蕉国产|