稀疏矩阵相加

问题及代码:

/*  
* Copyright (c) 2015, 烟台大学计算机与控制工程学院  
* All rights reserved.  
* 文件名称: main.cpp 
* 作者:高哲 
* 完成日期:2015年12月13日  
* 版本号:codeblocks   
* 问题描述:  采用三元组存储稀疏矩阵,设计两个稀疏矩阵相加的运算算法 
* 输入描述: 无
* 程序输出: 见运行结果  
*/   
#ifndef TUP_H_INCLUDED  
#define TUP_H_INCLUDED  
#include<stdio.h>  
#define M 6  
#define N 7  
#define MaxSize 100  
typedef int ElemType;  
typedef struct  
{  
    int r;  
    int c;  
    ElemType d;  
}TupNode;  
typedef struct  
{  
    int rows;  
    int cols;  
    int nums;  
    TupNode data[MaxSize];  
}TSMatrix;  
void CreatMat(TSMatrix &t,ElemType A[M][N]);  //从一个二维稀疏矩阵创建其三元组表示  
bool Value(TSMatrix &t,ElemType x,int i,int j);  //三元组元素赋值  
bool Assign(TSMatrix t,ElemType &x,int i,int j); //将指定位置的元素值赋给变量  
void DispMat(TSMatrix t);//输出三元组  
bool MatAdd(TSMatrix a,TSMatrix b,TSMatrix &c);  
#endif // TUP_H_INCLUDED  
/*
* Copyright (c) 2015, 烟台大学计算机与控制工程学院
* All rights reserved.
* 文件名称: main.cpp,tup.cpp,tup.h
* 作者:巩凯强
* 完成日期:2015年11月1日
* 版本号:codeblocks
*
* 问题描述:  采用三元组存储稀疏矩阵,设计两个稀疏矩阵相加的运算算法
* 输入描述: 无
* 程序输出: 见运行结果
*/
#ifndef TUP_H_INCLUDED
#define TUP_H_INCLUDED
#include<stdio.h>
#define M 6
#define N 7
#define MaxSize 100
typedef int ElemType;
typedef struct
{
    int r;
    int c;
    ElemType d;
}TupNode;
typedef struct
{
    int rows;
    int cols;
    int nums;
    TupNode data[MaxSize];
}TSMatrix;
void CreatMat(TSMatrix &t,ElemType A[M][N]);  //从一个二维稀疏矩阵创建其三元组表示
bool Value(TSMatrix &t,ElemType x,int i,int j);  //三元组元素赋值
bool Assign(TSMatrix t,ElemType &x,int i,int j); //将指定位置的元素值赋给变量
void DispMat(TSMatrix t);//输出三元组
bool MatAdd(TSMatrix a,TSMatrix b,TSMatrix &c);
#endif // TUP_H_INCLUDED





[csharp] view plaincopyprint?
#include"tup.h"  
void CreatMat(TSMatrix &t,ElemType A[M][N])  
{  
    int i,j;  
    t.rows=M;  
    t.cols=N;  
    t.nums=0;  
    for(i=0;i<M;i++)  
    {  
        for(j=0;j<N;j++)  
        {  
            if(A[i][j]!=0)  
            {  
                t.data[t.nums].r=i;  
                t.data[t.nums].c=j;  
                t.data[t.nums].d=A[i][j];  
                t.nums++;  
            }  
        }  
    }  
}  
bool Value(TSMatrix &t,ElemType x,int i,int j)  
{  
    int k=0,k1;  
    if(i>=t.rows||j>=t.cols)  
        return false;  
    while(k<t.nums&&i>t.data[k].r)  
    {  
        k++;  
    }  
    while(k<t.nums&&i==t.data[k].r&&j>t.data[k].c)  
    {  
        k++;  
    }  
    if(t.data[k].r==i&&t.data[k].c==j)  
    {  
        t.data[k].d=x;  
    }  
    else  
    {  
        for(k1=t.nums-1;k1>=k;k1--)  
        {  
            t.data[k1+1].r=t.data[k1].r;  
            t.data[k1+1].c=t.data[k1].c;  
            t.data[k1+1].d=t.data[k1].d;  
        }  
        t.data[k].r=i;  
        t.data[k].c=j;  
        t.data[k].d=x;  
        t.nums++;  
    }  
    return true;  
}  
bool Assign(TSMatrix t,ElemType &x,int i,int j)  
{  
    int k=0;  
    if(i>=t.rows||j>=t.cols)  
        return false;  
    while(k<t.nums&&i>t.data[k].r)  
    {  
        k++;  
    }  
    while(k<t.nums&&i==t.data[k].r&&j>t.data[k].c)  
    {  
        k++;  
    }  
    if(t.data[k].r==i&&t.data[k].c==j)  
        x=t.data[k].d;  
    else  
        x=0;  
    return false;  
}  
void DispMat(TSMatrix t)  
{  
    int i;  
    if(t.nums<=0)  
    {  
        return ;  
    }  
    printf("\t%d\t%d\t%d\n",t.rows,t.cols,t.nums);  
    printf("\t------------------\n");  
    for (i=0; i<t.nums; i++)  
        printf("\t%d\t%d\t%d\n",t.data[i].r,t.data[i].c,t.data[i].d);  
}  
  
bool MatAdd(TSMatrix a,TSMatrix b,TSMatrix &c)  
{  
    int i,j;  
    ElemType va,vb,vc;  
    if (a.rows!=b.rows || a.cols!=b.cols)  
        return false;                        //行数或列数不等时不能进行相加运算  
    c.rows=a.rows;  
    c.cols=a.cols;       //c的行列数与a的相同  
    c.nums=0;  
    for(i=0; i<M; i++)  
        for(j=0; j<N; j++)  
        {  
            Assign(a,va,i,j);  
            Assign(b,vb,i,j);  
            vc=va+vb;  
            if(vc)  
                Value(c,vc,i,j);  
        }  
    return true;  
}  
#include"tup.h"
void CreatMat(TSMatrix &t,ElemType A[M][N])
{
    int i,j;
    t.rows=M;
    t.cols=N;
    t.nums=0;
    for(i=0;i<M;i++)
    {
        for(j=0;j<N;j++)
        {
            if(A[i][j]!=0)
            {
                t.data[t.nums].r=i;
                t.data[t.nums].c=j;
                t.data[t.nums].d=A[i][j];
                t.nums++;
            }
        }
    }
}
bool Value(TSMatrix &t,ElemType x,int i,int j)
{
    int k=0,k1;
    if(i>=t.rows||j>=t.cols)
        return false;
    while(k<t.nums&&i>t.data[k].r)
    {
        k++;
    }
    while(k<t.nums&&i==t.data[k].r&&j>t.data[k].c)
    {
        k++;
    }
    if(t.data[k].r==i&&t.data[k].c==j)
    {
        t.data[k].d=x;
    }
    else
    {
        for(k1=t.nums-1;k1>=k;k1--)
        {
            t.data[k1+1].r=t.data[k1].r;
            t.data[k1+1].c=t.data[k1].c;
            t.data[k1+1].d=t.data[k1].d;
        }
        t.data[k].r=i;
        t.data[k].c=j;
        t.data[k].d=x;
        t.nums++;
    }
    return true;
}
bool Assign(TSMatrix t,ElemType &x,int i,int j)
{
    int k=0;
    if(i>=t.rows||j>=t.cols)
        return false;
    while(k<t.nums&&i>t.data[k].r)
    {
        k++;
    }
    while(k<t.nums&&i==t.data[k].r&&j>t.data[k].c)
    {
        k++;
    }
    if(t.data[k].r==i&&t.data[k].c==j)
        x=t.data[k].d;
    else
        x=0;
    return false;
}
void DispMat(TSMatrix t)
{
    int i;
    if(t.nums<=0)
    {
        return ;
    }
    printf("\t%d\t%d\t%d\n",t.rows,t.cols,t.nums);
    printf("\t------------------\n");
    for (i=0; i<t.nums; i++)
        printf("\t%d\t%d\t%d\n",t.data[i].r,t.data[i].c,t.data[i].d);
}

bool MatAdd(TSMatrix a,TSMatrix b,TSMatrix &c)
{
    int i,j;
    ElemType va,vb,vc;
    if (a.rows!=b.rows || a.cols!=b.cols)
        return false;                        //行数或列数不等时不能进行相加运算
    c.rows=a.rows;
    c.cols=a.cols;       //c的行列数与a的相同
    c.nums=0;
    for(i=0; i<M; i++)
        for(j=0; j<N; j++)
        {
            Assign(a,va,i,j);
            Assign(b,vb,i,j);
            vc=va+vb;
            if(vc)
                Value(c,vc,i,j);
        }
    return true;
}




#include "tup.h"  
int main()  
{  
    TSMatrix ta,tb,tc;  
    int A[M][N]=  
    {  
        {0,0,1,0,0,0,0},  
        {0,2,0,0,0,0,0},  
        {3,0,0,0,0,0,0},  
        {0,0,0,5,0,0,0},  
        {0,0,0,0,6,0,0},  
        {0,0,0,0,0,7,4}  
    };  
    int B[M][N]=  
    {  
        {0,0,10,0,0,0,0},  
        {0,0,0,20,0,0,0},  
        {0,0,0,0,0,0,0},  
        {0,0,0,50,0,0,0},  
        {0,0,20,0,0,0,0},  
        {0,0,0,10,0,0,4}  
    };  
    CreatMat(ta,A);  
    CreatMat(tb,B);  
    printf("A:\n");  
    DispMat(ta);  
    printf("B:\n");  
    DispMat(tb);  
    if(MatAdd(ta, tb, tc))  
    {  
        printf("A+B:\n");  
        DispMat(tc);  
    }  
    else  
    {  
        printf("相加失败\n");  
    }  
    return 0;  
}  

运行结果:
<img src="https://img-blog.csdn.net/20151213143831098?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />


 

知识点总结:

采用三元组存储稀疏矩阵的算法,将两个稀疏矩阵相加

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用,我们可以使用三元组顺序表来表示稀疏矩阵,并实现两个矩阵相加运算。具体步骤如下: 1. 首先输入两个矩阵的行数和列数,以及非零元素的个数。 2. 然后输入每个非零元素的行、列和值,分别存储在三元组顺序表中。 3. 对于两个矩阵相加运算,我们可以先将两个矩阵的三元组顺序表按照行和列的大小排序,然后依次比较每个非零元素的行和列,进行相应的加法运算。 4. 最后将结果矩阵以通常的阵列形式列出。 下面是一个示例代码,用于实现两个稀疏矩阵相加运算: ```c #include <stdio.h> #define MAXSIZE 100 typedef struct { int row; int col; int val; } Triple; typedef struct { Triple data[MAXSIZE + 1]; int rows, cols, nums; } TSMatrix; void CreateSMatrix(TSMatrix *M) { printf("请输入矩阵的行数、列数和非零元素的个数:\n"); scanf("%d%d%d", &M->rows, &M->cols, &M->nums); printf("请输入每个非零元素的行、列和值:\n"); for (int i = 1; i <= M->nums; i++) { scanf("%d%d%d", &M->data[i].row, &M->data[i].col, &M->data[i].val); } } void PrintSMatrix(TSMatrix M) { int k = 1; for (int i = 1; i <= M.rows; i++) { for (int j = 1; j <= M.cols; j++) { if (M.data[k].row == i && M.data[k].col == j) { printf("%d ", M.data[k].val); k++; } else { printf("0 "); } } printf("\n"); } } void AddSMatrix(TSMatrix M, TSMatrix N, TSMatrix *Q) { if (M.rows != N.rows || M.cols != N.cols) { printf("两个矩阵的行数或列数不相等,无法相加!\n"); return; } int i = 1, j = 1, k = 1; while (i <= M.nums && j <= N.nums) { if (M.data[i].row < N.data[j].row || (M.data[i].row == N.data[j].row && M.data[i].col < N.data[j].col)) { Q->data[k++] = M.data[i++]; } else if (M.data[i].row > N.data[j].row || (M.data[i].row == N.data[j].row && M.data[i].col > N.data[j].col)) { Q->data[k++] = N.data[j++]; } else { int sum = M.data[i].val + N.data[j].val; if (sum != 0) { Q->data[k].row = M.data[i].row; Q->data[k].col = M.data[i].col; Q->data[k].val = sum; k++; } i++; j++; } } while (i <= M.nums) { Q->data[k++] = M.data[i++]; } while (j <= N.nums) { Q->data[k++] = N.data[j++]; } Q->rows = M.rows; Q->cols = M.cols; Q->nums = k - 1; } int main() { TSMatrix M, N, Q; CreateSMatrix(&M); CreateSMatrix(&N); AddSMatrix(M, N, &Q); printf("矩阵M:\n"); PrintSMatrix(M); printf("矩阵N:\n"); PrintSMatrix(N); printf("矩阵M+N:\n"); PrintSMatrix(Q); return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值