| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 563 人关注过本帖
标题:C++矩阵运算题,求大神解答
只看楼主 加入收藏
重载
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2015-6-11
结帖率:100%
收藏
 问题点数:0 回复次数:1 
C++矩阵运算题,求大神解答
矩阵运算
设有两个3行3列矩阵A、B,求两矩阵的和、差、乘。
A+B=(aij+bij)
A-    B=(aij-bij)
2015-06-13 07:56
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9024
专家分:54030
注 册:2011-1-18
收藏
得分:0 
以 + 为例:
程序代码:
#include <iostream>

template<typename T, size_t ROW, size_t COL>
class Matrix;

template<typename T, size_t ROW, size_t COL>
std::ostream& operator<<( std::ostream& os, const Matrix<T,ROW,COL>& m );

template<typename T, size_t ROW, size_t COL>
class Matrix
{
public:
    Matrix()
    {
        for( size_t r=0; r!=ROW; ++r )
            for( size_t c=0; c!=COL; ++c )
                value_[r][c] = T();
    }
    Matrix( const std::initializer_list<T>& list )
    {
        auto itor = std::begin(list);
       

        for( size_t r=0; r!=ROW; ++r )
            for( size_t c=0; c!=COL; ++c )
                if( itor != std::end(list) )
                    value_[r][c] = *itor++;
                else
                    value_[r][c] = T();
    }

    Matrix operator+( const Matrix& m ) const
    {
        Matrix ret;
        for( size_t r=0; r!=ROW; ++r )
            for( size_t c=0; c!=COL; ++c )
                ret.value_[r][c] = value_[r][c]+m.value_[r][c];
        return ret;
    }
private:
    T value_[ROW][COL];

    friend std::ostream& operator<< <T,ROW,COL> ( std::ostream& os, const Matrix<T,ROW,COL>& m );
};

template<typename T, size_t ROW, size_t COL>
std::ostream& operator<<( std::ostream& os, const Matrix<T,ROW,COL>& m )
{
    for( size_t r=0; r!=ROW; ++r )
    {
        for( size_t c=0; c!=COL; ++c )
            os << m.value_[r][c] << '\t';
        os << '\n';
    }
    return os;
}

using namespace std;

int main( void )
{
    Matrix<int,3,3> m1 = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
    Matrix<int,3,3> m2 = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
    cout << m1 << endl;
    cout << m2 << endl;
    cout << m1+m2 << endl;

    return 0;
}
输出
程序代码:
1       2       3
4       5       6
7       8       9

1       2       3
4       5       6
7       8       9

2       4       6
8       10      12
14      16      18

2015-06-15 10:10
快速回复:C++矩阵运算题,求大神解答
数据加载中...
 
   



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

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