1483 稀疏矩阵的压缩存储与相乘

 1 //稀疏矩阵乘法 行逻辑链接的三元组顺序表
 2 // 3 4
 3 // 6
 4 // 1 1 3
 5 // 1 2 2
 6 // 1 3 3
 7 // 1 4 5
 8 // 2 2 -1
 9 // 3 1 2
10 // 4 2
11 // 5
12 // 1 2 2
13 // 2 1 1
14 // 3 1 -2
15 // 3 2 4
16 // 4 1 2
17 #include <iostream>
18 #include <cstring>
19 #define  MAX_SIZE 2500+1
20 #define  MAX_RC   2500+1
21 using namespace std;
22 typedef int elemType;
23 typedef struct {
24     int i,j;
25     elemType e;
26 }Triple;
27 typedef struct{
28     Triple data[MAX_SIZE];
29     int    rowPos[MAX_RC];//各行第一个元素的秩表
30     int    mu,nu,tu;
31 }TripleSpareMatrix;
32 void creatTripleSpareMatrix(TripleSpareMatrix &tSM)
33 {
34     scanf("%d%d%d",&tSM.mu,&tSM.nu,&tSM.tu);
35     int rowNum[tSM.mu+1];
36     for (int i = 0; i < tSM.mu+1; ++i) rowNum[i]=0;//行元素数目累加器初始化
37     for(int k=1;k<=tSM.tu;k++)
38     {
39         scanf("%d%d%d",&tSM.data[k].i,&tSM.data[k].j,&tSM.data[k].e);
40         rowNum[tSM.data[k].i]++;
41     }
42     tSM.rowPos[1]=1;
43     for (int p = 2; p <=tSM.mu+1; ++p)//对不存在的第[tSm.mu+1]行统一处理
44         tSM.rowPos[p]=tSM.rowPos[p-1]+rowNum[p-1];
45 }
46 void multMatrix(TripleSpareMatrix tSM1,TripleSpareMatrix tSM2,TripleSpareMatrix &tSM3)
47 {
48     tSM3.mu=tSM1.mu; tSM3.nu=tSM2.nu; tSM3.tu=0;//tSM3初始化
49     for (int row = 1; row <= tSM1.mu; ++row)//遍历tSM3(同tSM1)的每一行
50     {
51         int colNum[tSM2.nu+1];
52         for (int i = 0; i < tSM2.nu+1; ++i) colNum[i]=0;//当前行个元素累加器初始化
53         tSM3.rowPos[row]=tSM3.tu+1;//
54         for (int p = tSM1.rowPos[row]; p <tSM1.rowPos[row+1]; ++p)//遍历当前的row行的每一个非零元
55             for (int q=tSM2.rowPos[tSM1.data[p].j]; q<tSM2.rowPos[tSM1.data[p].j+1]; ++q)//遍历与tSM1当前行的对应tSM2行(tSM1.data[p].j==tSM2.data[q].i)
56                 colNum[tSM2.data[q].j]+=tSM1.data[p].e*tSM2.data[q].e;//累加
57         for (int col = 1; col <= tSM2.nu; ++col)//压缩存储非零元
58             if(colNum[col])
59             {
60                 tSM3.tu++;
61                 tSM3.data[tSM3.tu].i=row; tSM3.data[tSM3.tu].j=col; tSM3.data[tSM3.tu].e=colNum[col];
62             }
63     }
64 }
65 void printMatrix(TripleSpareMatrix tSM)
66 {
67     for (int i = 1; i <=tSM.tu; ++i)
68         printf("%d %d %d\n",tSM.data[i].i,tSM.data[i].j,tSM.data[i].e );
69 }
70 int main(int argc, char const *argv[])
71 {
72     #ifndef _OJ_  //ONLINE_JUDGE
73     freopen("input.txt", "r", stdin);
74     #endif
75     TripleSpareMatrix tSM1,tSM2,tSM3;
76     creatTripleSpareMatrix(tSM1);
77     creatTripleSpareMatrix(tSM2);
78     multMatrix(tSM1,tSM2,tSM3);
79     printMatrix(tSM3);
80     return 0;
81 }

 

posted @ 2015-02-13 12:00  swanGooseMan  阅读(259)  评论(0编辑  收藏  举报