【程序填空题】矩阵(运算符重载)

题目描述

下面主函数和Array类完成矩阵的输入、输出。请补齐Array类中需要的成员函数。

提示:根据已给代码分析CArray需要重载哪些运算符?

输入

测试次数

每组测试数据格式如下:

正整数n、m,分表表示矩阵的行、列

n*m行整数数据

输出

每组测试数据输出矩阵数据两次,具体输出格式见样例。

//

输入样例:

2

3 3

1 2 3

4 5 6

7 8 9

2 4

10 20 30 40

50 60 70 80

输出样例:

MatrixA:

1 2 3

4 5 6

7 8 9

MatrixB:

1 2 3

4 5 6

7 8 9

MatrixA:

10 20 30 40

50 60 70 80

MatrixB:

10 20 30 40

50 60 70 80

代码板块:

#include <iostream>

using namespace std;

class CArray //矩阵类

{

int n, m; //n行,m列

int **data; //存储矩阵数据

public:

CArray():data(nullptr){}

CArray(int nValue, int mValue);

~CArray();

//补齐CArray的其它成员函数及实现

/********** Write your code here! **********/

/*******************************************/

//CArray构造函数

CArray::CArray(int nValue, int mValue) : n(nValue), m(mValue)

{

// 分配n行m列空间

data = new int *[n];

for (int i = 0; i < n; i++)

{

data[i] = new int[m];

}

}

//CArray析构函数

CArray::~CArray()

{

// 释放空间

for (int i = 0; i < n; i++)

{

delete[] data[i];

}

delete[] data;

}

//主函数

int main()

{

int t;

int n, m;

int i, j;

cin >> t;

while (t--)

{

cin >> n >> m; // 输入矩阵行n, 列m

CArray matrixA(n, m); // 定义matrixA对象

for (i = 0; i < n; ++i) // 输入n行m列数据

for (j = 0; j < m; j++)

cin >> matrixA[i][j];

cout << "MatrixA:" << endl;

for (i = 0; i < n; ++i) // 输出matrixA中的数据

{

for (j = 0; j < m; j++)

{

cout << matrixA(i,j) << " ";

}

cout << endl;

}

cout << "MatrixB:" << endl;

CArray matrixB; // 定义matrixB对象

matrixB = matrixA; // 赋值

for (i = 0; i < n; ++i) // 输出matrixB对象

{

for (j = 0; j < m; j++)

{

cout << matrixB[i][j] << " ";

}

cout << endl;

}

}

return 0;

}

AC代码:

cpp 复制代码
#include <iostream>
using namespace std;
class CArray // 矩阵类
{
    int n, m;   // n行,m列
    int **data; // 存储矩阵数据
public:
    CArray() : data(nullptr) {}
    CArray(int nValue, int mValue);
    ~CArray();
    // 补齐CArray的其它成员函数及实现
    CArray &operator=(const CArray &rhs)
    {
        if (this == &rhs)
            return *this;
        if (data)
            delete[] data;
        n = rhs.n;
        m = rhs.m;
        data = new int *[n];
        for (int i = 0; i < n; i++)
        {
            data[i] = new int[m];
        }
        for (int i = 0; i < n; i++)
            for (int j = 0; j < m; j++)
            {
                {
                    data[i][j] = rhs.data[i][j];
                }
            }
        return *this;
    }

    int *operator[](int index)
    {
        return data[index];
    }

    int &operator()(int i, int j) const
    {
        return data[i][j];
    }
};

// CArray构造函数
CArray::CArray(int nValue, int mValue) : n(nValue), m(mValue)
{
    // 分配n行m列空间
    data = new int *[n];
    for (int i = 0; i < n; i++)
    {
        data[i] = new int[m];
    }
}
// CArray析构函数
CArray::~CArray()
{
    // 释放空间
    for (int i = 0; i < n; i++)
    {
        delete[] data[i];
    }
    delete[] data;
}
// 主函数
int main()
{
    int t;
    int n, m;
    int i, j;
    cin >> t;
    while (t--)
    {
        cin >> n >> m;          // 输入矩阵行n, 列m
        CArray matrixA(n, m);   // 定义matrixA对象
        for (i = 0; i < n; ++i) // 输入n行m列数据
            for (j = 0; j < m; j++)
                cin >> matrixA[i][j];
        cout << "MatrixA:" << endl;
        for (i = 0; i < n; ++i) // 输出matrixA中的数据
        {
            for (j = 0; j < m; j++)
            {
                cout << matrixA(i, j) << " ";
            }
            cout << endl;
        }
        cout << "MatrixB:" << endl;
        CArray matrixB;         // 定义matrixB对象
        matrixB = matrixA;      // 赋值
        for (i = 0; i < n; ++i) // 输出matrixB对象
        {
            for (j = 0; j < m; j++)
            {
                cout << matrixB[i][j] << " ";
            }
            cout << endl;
        }
    }
    return 0;
}
相关推荐
IT从业者张某某10 分钟前
机器学习-04-分类算法-03KNN算法案例
算法·机器学习·分类
chen_song_14 分钟前
WebRTC的ICE之TURN协议的交互流程中继转发Relay媒体数据的turnserver的测试
算法·音视频·webrtc·交互·媒体
蒙奇D索大30 分钟前
【数据结构】图解图论:度、路径、连通性,五大概念一网打尽
数据结构·考研·算法·图论·改行学it
uhakadotcom34 分钟前
2025年春招:如何使用DeepSeek + 豆包优化简历,轻松敲开心仪公司的大门
算法·面试·github
小白狮ww38 分钟前
Retinex 算法 + MATLAB 软件,高效率完成图像去雾处理
开发语言·人工智能·算法·matlab·自然语言处理·图像识别·去雾处理
trust Tomorrow2 小时前
每日一题-力扣-2278. 字母在字符串中的百分比 0331
算法·leetcode
Lecea_L2 小时前
你能在K步内赚最多的钱吗?用Java解锁最大路径收益算法(含AI场景分析)
java·人工智能·算法
Tony882 小时前
热题100 - 394. 字符串解码
java·算法
Lecea_L2 小时前
🔍 找到数组里的“节奏感”:最长等差子序列
java·算法
是Dream呀2 小时前
ResNeXt: 通过聚合残差变换增强深度神经网络
人工智能·算法