第九周 项目2-对称矩阵压缩储存的实现与应用(续)

原创 2015年11月20日 09:11:54
/*
Copyright (c)2015,烟台大学计算机与控制工程学院
All rights reserved.
文件名称:项目2-2.cbp
作   者:孙钰坤
完成日期:2015年11月20日
版 本 号:v1.0

问题描述:设计算法,实现两个用压缩形式存储的对称矩阵A和B的加法和乘法。实现中请使用好前面设计的基本运算。

输入描述:无
程序输出:测试结果
*/


代码:

 

 

#include <stdio.h>   
#define N 4   
#define M 10   
int value(int a[],int i,int j)  
{  
    if (i>=j)  
        return a[(i*(i+1))/2+j];  
    else  
        return a[(j*(j+1))/2+i];  
}  
void madd(int a[],int b[],int c[][N])  
{  
    int i,j;  
   for (i=0; i<N; i++)  
        for (j=0; j<N; j++)  
            c[i][j]=value(a,i,j)+value(b,i,j);  
}  
void mult(int a[],int b[],int c[][N])  
{  
   int i,j,k,s;  
    for (i=0; i<N; i++)  
        for (j=0; j<N; j++)  
        {  
            s=0;  
            for (k=0; k<N; k++)  
                s=s+value(a,i,k)*value(b,k,j);  
            c[i][j]=s;  
        }  
}  
void disp1(int a[])  
{  
    int i,j;  
    for (i=0; i<N; i++)  
   {  
        for (j=0; j<N; j++)  
            printf("%4d",value(a,i,j));  
        printf("\n");  
   }  
}  
void disp2(int c[][N])  
{  
    int i,j;  
    for (i=0; i<N; i++)  
    {  
        for (j=0; j<N; j++)  
            printf("%4d",c[i][j]);  
        printf("\n");  
    }  
}  
int main()  
{  
    int a[M]= {1,2,3,4,5,6,7,8,9,10};  //a表示压缩存储的对称矩阵   
    int b[M]= {1,1,1,1,1,1,1,1,1,1};  
    int c1[N][N],c2[N][N];  
    madd(a,b,c1);  
    mult(a,b,c2);  
    printf("a矩阵:\n");  
    disp1(a);  
    printf("b矩阵:\n");  
    disp1(b);  
    printf("a+b:\n");  
    disp2(c1);  
    printf("a×b:\n");  
    disp2(c2);  
    printf("\n");  
    return 0;  
}  


运行结果:

 

 

 

版权声明:吃了我的给我吐出来b( ̄▽ ̄)d

数据结构例程——对称矩阵的压缩存储及基本运算

本文针对数据结构基础系列网络课程(5):数组与广义表中第2课时特殊矩阵的压缩存储。问题:用压缩形式存储对称矩阵,实现下面的操作并测试 void Init(int *&b);//为N阶对称矩阵初始化存储...
  • sxhelijian
  • sxhelijian
  • 2015年10月07日 16:21
  • 5751

将对称矩阵压缩存储,实现矩阵相乘,输出相乘后结果(用二维数组)

数组地址的传送是我很容易弄错的地方,很惭愧没有学好c和c++知识,现将代码粘如下,还需改进。不是很完美! #include "stdafx.h" #include #include #include ...
  • qq_28598203
  • qq_28598203
  • 2016年04月12日 23:17
  • 1170

三对角矩阵压缩存储--注意对角元素的下标

三对角矩阵压缩存储--注意对角元素的下标 对角矩阵的压缩存储   对角矩阵是指所有非零元素全部集中在中心几条对角线上的矩阵。下面以三对角矩阵(所有非零元素集中在中心三条对角线上)为例描述对角矩阵的...
  • moyanmalin
  • moyanmalin
  • 2016年08月13日 09:40
  • 2297

第九周--项目2-对称矩阵压缩储存的实现与应用

问题描述及代码: /* 文件名称:第9周项目2 - 对称矩阵压缩存储的实现与应用(2).cpp 作 者:刘春彤 完成日期:2016年10月25日 版 本 号:v1.0 问题描述: (2)设计算...
  • lct97
  • lct97
  • 2016年10月25日 10:07
  • 70

第九周项目二 对称矩阵压缩存储的实现与应用(2)

问题及代码: /* *烟台大学计算机与控制工程学院 *作 者:孙丽玮 *完成日期:2016年10月27日 *问题描述:设计算法,实现两个用压缩形式存储的对称矩阵A和B的加...
  • AFencounter
  • AFencounter
  • 2016年10月27日 11:13
  • 116

第九周项目2- 对称矩阵压缩存储的实现与应用

/*Copyright (c) 2015, 烟台大学计算机与控制工程学院 * All rights reserved. * 文件名称:H.cpp * 作者:辛志勐 * 完成日期:2015年10月29日...
  • E_miss
  • E_miss
  • 2015年10月29日 19:47
  • 354

【数组项目2-1 - 对称矩阵压缩存储的实现与应用——第九周】

数据结构例程——对称矩阵的压缩存储及基本运算 /* * Copyright (c) 2015, 烟台大学计算机与控制工程学院 * All rights reserved. * 文件名...
  • xjp_xujiping
  • xjp_xujiping
  • 2015年11月01日 11:17
  • 387

第九周 项目2 - 对称矩阵压缩存储的实现与应用

问题及代码:/* Copyright (c)2015,烟台大学计算机与控制工程学院 All rights reserved. 文件名称:项目1.cbp 作 者:马笑媛 完成日期...
  • mxyyy123
  • mxyyy123
  • 2015年10月30日 08:47
  • 234

第九周项目2-对称矩阵压缩存储的实现与应用(1)

copyright (c) 2016,烟台大学计算机学院    All rights reserved.    文件名称:1.cpp    作者:孟令康   完成日期:2016年9月12日    版本...
  • mlk5739_csdn
  • mlk5739_csdn
  • 2016年11月03日 10:40
  • 59

第九周项目2-对称矩阵压缩存储的实现与应用(1)

/*    * Copyright (c) 2016, 烟台大学计算机与控制工程学院    * All rights reserved。    * 文件名称 :1.cpp    * 作    ...
  • mlq9527
  • mlq9527
  • 2016年10月27日 10:43
  • 93
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:第九周 项目2-对称矩阵压缩储存的实现与应用(续)
举报原因:
原因补充:

(最多只允许输入30个字)