稀疏矩阵的加法(用十字链表实现A=A+B) 您所在的位置:网站首页 三元组表加法 稀疏矩阵的加法(用十字链表实现A=A+B)

稀疏矩阵的加法(用十字链表实现A=A+B)

2024-06-09 06:35| 来源: 网络整理| 查看: 265

描述:

输入两个稀疏矩阵A和B,用十字链表实现A=A+B,输出它们相加的结果。

输入:

第一行输入四个正整数,分别是两个矩阵的行m、列n、第一个矩阵的非零元素的个数t1和第二个矩阵的非零元素的个数t2,接下来的t1+t2行是三元组,分别是第一个矩阵的数据和第二个矩阵的数据, 三元组的第一个元素表示行,第二个元素表示列,第三个元素是该元素的值。

输出:

输出相加后的矩阵三元组。

输入样例:

3 4 3 2 1 1 1 1 3 1 2 2 2 1 2 1 2 2 3

输出样例:

1 1 1 1 2 1 1 3 1 2 2 5

#include #include typedef struct OLNODE { int row,col; int data; struct OLNODE *right,*down; } NODE,*LNODE; typedef struct CORSS { LNODE *rh,*ch; int ra,ca,da; } CROSS, *LCROSS; void Create(LCROSS A); void PlusToA(LCROSS A,LCROSS B); void PrintCross(LCROSS A); int main() { LCROSS A = (LCROSS)malloc(sizeof(CROSS)); LCROSS B = (LCROSS)malloc(sizeof(CROSS)); scanf("%d %d %d %d",&A->ra,&A->ca,&A->da,&B->da); B->ra = A->ra; B->ca = A->ca; Create(A); Create(B);//" 3 4 0 5 创建时B有问题" PlusToA(A,B); PrintCross(A); return 0; } void Create(LCROSS M) { int i; LNODE p,temp; M->rh = (LNODE *)malloc((M->ra+1)*sizeof(LNODE)); M->ch = (LNODE *)malloc((M->ca+1)*sizeof(LNODE)); for(i=1; ira; i++) { M->rh[i]=NULL; } /*for(i=1; ica; i++) { M->ch[i]=NULL; }*/ if(M->da != 0) { for(i=1; ida; i++) { p=(LNODE)malloc(sizeof(NODE)); scanf("%d %d %d",&p->row,&p->col,&p->data); if(M->rh[p->row] == NULL) { p->right=NULL; M->rh[p->row] = p; } else { for(temp=M->rh[p->row];; temp=temp->right) { if(temp->right == NULL) { temp->right = p; p->right =NULL; break; } else if(temp->col < p->col && temp->right->col>p->col) { p->right = temp->right; temp->right = p; break; } else if(temp==M->rh[p->row] && temp->col>p->col) { p->right = temp; temp=p; break; } } } /* if(M->ch[p->col] == NULL|| M->ch[p->col]->row>(p->row)) { p->down=M->ch[p->col]; M->ch[p->col] = p; } else { for(temp=M->ch[p->col]; temp->down && temp->down->rowrow; temp=temp->down); p->down = temp->down; temp->down = p; }*/ } } } void PlusToA(LCROSS A,LCROSS B) { int i; LNODE p,temp1,temp2; for(i=1; ira; i++) { if(B->rh[i] == NULL) continue; else { if(A->rh[i] == NULL) { p=(LNODE)malloc(sizeof(NODE)); p->col = B->rh[i]->col; p->row = B->rh[i]->row; p->data = B->rh[i]->data; A->rh[i]=p; p->right = NULL; B->rh[i]=B->rh[i]->right; } if(B->rh[i]==NULL)continue; for(temp1=B->rh[i];; temp1=temp1->right) { for(temp2=A->rh[i];; temp2=temp2->right) { if(temp2->col == temp1->col) { temp2->data+=temp1->data; break; } else if(temp2==A->rh[i] && temp1->colcol) { p=(LNODE)malloc(sizeof(NODE)); p->col = temp1->col; p->row = temp1->row; p->data = temp1->data; p->right = temp2->right; p->right =temp2; A->rh[i]=p; break; } else if((temp2->right == NULL || temp2->right->col>temp1->col) && temp1->col>temp2->col) { p=(LNODE)malloc(sizeof(NODE)); p->col = temp1->col; p->row = temp1->row; p->data = temp1->data; p->right = temp2->right; temp2->right=p; break; } } if(temp1->right == NULL) break; } } } } void PrintCross(LCROSS A) { int i; LNODE p; for(i=1; ira; i++) { p=A->rh[i]; while(p!=NULL) { printf("%d %d %d\n",p->row,p->col,p->data); p=p->right; } } }

TIP:

1、仅使用了十字链表中的行链表,列链表被注释掉了,因为本题中没用。

2、注意修改链表时一定要修改原链表变量!!

如,定义链表A,temp=A,修改temp=p不能达到修改链表A=p的目的。



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

      专题文章
        CopyRight 2018-2019 实验室设备网 版权所有