zoukankan      html  css  js  c++  java
  • YTU 2640: 编程题:运算符重载---矩阵求和

    2640: 编程题:运算符重载---矩阵求和

    时间限制: 1 Sec  内存限制: 128 MB
    提交: 484  解决: 190

    题目描述

    /*
    有两个矩阵a和b,均为2行3列。求两个矩阵之和。
    重载运算符“+”,使之能用于矩阵相加(如c=a+b)。
    重载流插入运算符“<<”和流提取运算符“>>”,使之能用于该矩阵的输入和输出。
    请在下面的程序段基础上完成设计,只提交begin到end部分的代码 */
    #include <iostream>
    using namespace std;
    class Matrix
    {
    public:
        Matrix();
        friend Matrix operator+(Matrix &,Matrix &);
        friend ostream& operator<<(ostream&,Matrix&);
        friend istream& operator>>(istream&,Matrix&);
    private:
        int mat[2][3];
    };
    Matrix::Matrix()
    {
        int i,j;
    for(i=0;i<2;i++)
    for(j=0;j<3;j++)
    mat[i][j]=0; 
    }
    istream & operator>>(istream &  input,Matrix & m)
    {
        int i,j;
    for(i=0;i<2;i++)
    for(j=0;j<3;j++)
    input>>m.mat[i][j];
    return input;
    }
    //将程序需要的其他成份写在下面,只提交begin到end部分的代码
    //******************** begin ********************
    //********************* end ********************
    int main()
    {
        Matrix a,b,c;
        cin>>a;
        cin>>b;
        c=a+b;
        cout<<c<<endl;
        return 0;
    }

    输入

    两个2行3列矩阵

    输出

    矩阵之和

    样例输入

    1 2 3
    4 5 6
    
    7 8 9
    0 1 2
    

    样例输出

    8 10 12 
    4 6 8 

    提示

    只提交begin到end部分的代码


    迷失在幽谷中的鸟儿,独自飞翔在这偌大的天地间,却不知自己该飞往何方……

    #include <iostream>
    using namespace std;
    class Matrix
    {
    public:
        Matrix();
        friend Matrix operator+(Matrix &,Matrix &);
        friend ostream& operator<<(ostream&,Matrix&);
        friend istream& operator>>(istream&,Matrix&);
    private:
        int mat[2][3];
    };
    Matrix::Matrix()
    {
        int i,j;
        for(i=0; i<2; i++)
            for(j=0; j<3; j++)
                mat[i][j]=0;
    }
    istream & operator>>(istream &  input,Matrix & m)
    {
        int i,j;
        for(i=0; i<2; i++)
            for(j=0; j<3; j++)
                input>>m.mat[i][j];
        return input;
    }
    Matrix operator+(Matrix &m1,Matrix &m2)
    {
        Matrix m;
        for(int i=0; i<2; ++i)
            for(int j=0; j<3; ++j)
            {
                m.mat[i][j]=m1.mat[i][j]+m2.mat[i][j];
            }
        return m;
    }
    ostream& operator <<(ostream &output,Matrix &m)
    {
        int i,j;
        for(i=0; i<2; ++i)
        {
            for( j=0; j<3; ++j)
            {
                output<<m.mat[i][j]<<" ";
            }
            output<<endl;
        }
        return output;
    }
    int main()
    {
        Matrix a,b,c;
        cin>>a;
        cin>>b;
        c=a+b;
        cout<<c<<endl;
        return 0;
    }
    

  • 相关阅读:
    洛谷 P1026 [NOIP2001 提高组] 统计单词个数
    CodeForces
    CodeForces
    常用的正则表达式(复制粘贴即可)
    Vue生命周期
    前端开发面试题
    前端Vue中动态使用本地图片路径
    《剑指offer》面试题13 在O(1)时间删除链表节点 Java版
    《剑指offer》面试题12 打印1到最大的n位数 Java版
    《剑指offer》面试题11 数值的整数次方 Java版
  • 原文地址:https://www.cnblogs.com/im0qianqian/p/5989506.html
Copyright © 2011-2022 走看看