| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1202 人关注过本帖
标题:关于指针矩阵的问题.
只看楼主 加入收藏
渴望成长
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2009-6-22
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:3 
关于指针矩阵的问题.
#include <stdio.h>
#include <stdlib.h>
void main()
{
    int *a,*b,*c;
    int m,n,p;
    int i,j,k,temp;
    
    printf("请输入矩阵a的维数(m,n):\n");
    printf("m= ");
    scanf("%d",&m);
    printf("n= ");
    scanf("%d",&n);
    a = (int*)malloc(m*n*sizeof(int));
    printf("[请输入矩阵a的各个元素]\n");
    for(i=0;i<m;i++)
    for(j=0;j<n;j++)
    {
        printf("a%d%d=",i,j);
        scanf("%d",&a[i*n+j]);
    }
    
    printf("请输入矩阵b的维数(n,p):\n");
    printf("n= ");
    scanf("%d",&n);
    printf("p= ");
    scanf("%d",&p);
    b = (int*)malloc(n*p*sizeof(int));
    printf("[请输入矩阵b的各个元素]\n");
    for(i=0;i<n;i++)
    for(j=0;j<p;j++)
    {
        printf("b%d%d= ",i,j);
        scanf("%d",&b[i*p+j]);
    }
    
    c = (int*)malloc(m*p*sizeof(int));
    if( m<=0 || n<=0 || p<=0 )
    {
        printf("[错误:维数m,n,p必须都大于0\n");
        return;
    }
    //从这---------------------------------------------------
    for(i=0;i<m;i++)
    for(j=0;j<p;j++)
    {
        temp = 0;
        for(k=0;k<n;k++)
        temp = temp + a[i*n+k] * b[k*p+j];
        c[i*p+j] = temp;
    }
    //到这---这几行语句到底起到了什么作用呢?麻烦高手详细讲解一下.
    printf("[a x b的结果是]\n");
    for(i=0;i<m;i++)
    {
        for(j=0;j<p;j++)
        printf("%d\t",c[i*p+j]);
        printf("\n");
    }
    system("pause");
    return;
}
搜索更多相关主题的帖子: 指针 矩阵 
2009-06-25 19:25
渴望成长
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2009-6-22
收藏
得分:0 
把程序复制编译器里,就可以看到我注释的想问的问题了...麻烦各位大虾解答一下!我是新人,脑子不好使...还没有适应c语言.
2009-06-25 19:26
渴望成长
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2009-6-22
收藏
得分:0 
教材上看到的这个程序,有点看不懂他的思路,所以发上阿里让各位打打帮忙分析一下.
3楼说的对,的确是求矩阵的乘法!
a和b两个矩阵相乘,a为m*n,b为n*p,然后a*b之后的结果为m*p的矩阵c;
2009-06-26 01:38
快速回复:关于指针矩阵的问题.
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020467 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved