| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1911 人关注过本帖
标题:[求助] 矩阵的n次方怎么求??用2维数组
只看楼主 加入收藏
a2680189
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2007-6-8
收藏
 问题点数:0 回复次数:4 
[求助] 矩阵的n次方怎么求??用2维数组
哪位大大知道,先谢谢了
搜索更多相关主题的帖子: 矩阵 
2007-06-10 02:25
herbert_1987
Rank: 5Rank: 5
等 级:贵宾
威 望:15
帖 子:1314
专家分:0
注 册:2007-5-13
收藏
得分:0 
设 有数组: a[m][m].//m 是矩阵的阶
b[m][m]
d[m][m] 是所求结果.
int i;
int j;
int count;
int sum;
int id;
for( i = 0; i < m; i++)
for( j = 0; j < m; j++)
d[i][j] = a[i][j];

for( count = 0; count < n; count++)//n 是矩阵的n次方
{
for( i = 0; i < m; i++)
for( j = 0; j < m; j++)
b[i][j] = d[i][j];

for( i = 0; i < m; i++)
for( j = 0; j < m; j++)
{
sum = 0;
for( id = 0; id < m; id++)
sum += a[id][j] + b[i][id];
d[i][j] = sum;
}

思路应该是这样,但没验证过有没有错误.

人生重要的不是所站的位置,而是所朝的方向
2007-06-10 03:08
a2680189
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2007-6-8
收藏
得分:0 

先谢谢了

2007-06-10 11:10
a2680189
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2007-6-8
收藏
得分:0 
回复:(a2680189)[求助] 矩阵的n次方怎么求??用2维数...

结果不对啊
main()
{ int n;
int i;
int j;
int count;
int sum;
int id;
int a[4][4],b[4][4],d[4][4];
printf(" cifang n\n");
scanf("%d",n);
for(i=0;i<4;i++)
{
for(j=0;j<4;j++)
scanf("%d",&a[i][j]);
d[i][j]=a[i][j];
}

for(i=0;i<4;i++)
{ printf("\n");
for(j=0;j<4;j++)
printf("%d",a[i][j]);
}
printf("\n\n");
for(count=0;count<n;count++)
{
for(i=0;i<4;i++)
{ for(j=0;j<4;j++)
b[i][j]=d[i][j];
}
for(i=0;i<4;i++)
{
for(j=0;j<4;j++)
{
sum=0;
for(id=0;id<4;id++)
sum+=a[id][j]*b[i][id];
d[i][j]=sum;
}

}
}
for(i=0;i<4;i++)
for(j=0;j<4;j++)
printf("d[%d][%d]=%d\n",i,j,d[i][j]);
}
结果不对啊

2007-06-10 12:50
herbert_1987
Rank: 5Rank: 5
等 级:贵宾
威 望:15
帖 子:1314
专家分:0
注 册:2007-5-13
收藏
得分:0 

改了一下,应该没问题了.
#include <stdio.h>

void main()
{ int n;
int i;
int j;
int count;
int sum;
int id;
int a[4][4],b[4][4],d[4][4];
printf(" cifang n\n");
scanf("%d",&n);

printf(" input 4 jie ju zheng:\n");
for(i=0;i<4;i++)
for(j=0;j<4;j++)
{
scanf("%d",&a[i][j]);
d[i][j]=a[i][j];
}

for(i=0;i<4;i++)
{
printf("\n");

for(j=0;j<4;j++)
printf("%d",a[i][j]);
}
printf("\n\n");

for( count = 1; count < n; count++)
{
for(i=0;i<4;i++)
{
for(j=0;j<4;j++)
b[i][j]=d[i][j];
}

for(i=0;i<4;i++)
{
for(j=0;j<4;j++)
{
sum = 0;
for(id=0;id<4;id++)
sum += b[i][id] * a[id][j];
d[i][j]=sum;
}
}
}

printf(" the result is: \n");
for(i=0;i<4;i++)
{
for(j=0;j<4;j++)
printf("%d ",d[i][j]);
printf("\n");
}
}


人生重要的不是所站的位置,而是所朝的方向
2007-06-10 13:24
快速回复:[求助] 矩阵的n次方怎么求??用2维数组
数据加载中...
 
   



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

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