第9週実践プロジェクト2—対称マトリクス圧縮ストレージの実現と応用(2)

1986 ワード

/* 
Copyright (c)2015,               
All rights reserved. 
    :  2-2.cbp 
      :    
    :2015 11 10  
     :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("
"); } } 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("
"); } } 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 :
"); disp1(a); printf("b :
"); disp1(b); printf("a+b:
"); disp2(c1); printf("a×b:
"); disp2(c2); printf("
"); return 0; } 
<img src="http://img.blog.csdn.net/20151109165121615" alt="" />