您的位置:首页 > 编程语言

编程将一个二维数组元素变换为逆向存放

2018-03-30 21:45 211 查看
编程将一个二维数组元素变换为逆向存放,即按元素在内存中的物理排列位置,第一个元素变成倒数第一个元素,第二个元素变成倒数第二个元素,依此类推。 例如,原始二维数组为,逆向存放后变为。试建立一个类REVARR,完成上述工作。具体要求如下:(1)私有数据成员int a[M]
:初始化时存放原始二维数组,最终存放逆向存放后的二维数组。(2)公有成员函数REVARR(int x[M]
):构造函数,用形参x初始化数据成员a。void reverse():按题目要求处理二维数组。void print():按二维数组方式输出a数组值。(3)在主函数中完成对该类的测试。在程序的开头,定义符号常数M和N的值分别为3和4,表示数组的行数和列数。在主函数中定义数组int data[M]
,其初值如上。定义一个REVARR类的对象arr,并用数组data初始化该对象的成员a,输出原数组值,然后调用成员函数逆序存放二维数组,最后输出逆序后的二维数组。
#include <iostream>
#include <iomanip>
#define M 3
#define N 4
using namespace std;

class REVARR
{
private:
int a[M]
;
public:
REVARR(int x[M]
);
void reverse();
void print();
};
REVARR::REVARR(int x[M]
)
{
int i, j;
for (i = 0; i < 3; i++)
for (j = 0; j < 4; j++)
a[i][j] = x[i][j];
}
void REVARR::reverse()
{
int t, i, j;
for (i = 0; i<M - 1; i++)
{
for (j = 0; j<N; j++)
{
t = a[i][j];
a[i][j] = a[M - i - 1][N - j - 1];
a[M - i - 1][N - j - 1] = t;

}
}
}
void REVARR::print()
{
int i, j;
for (i = 0; i <3; i++)
{
for (j = 0; j < 4; j++)
cout << setiosflags(ios::left) << setw(3) << a[i][j];

cout << endl;
}
}

int main()
{
int data[4][4] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 };
REVARR arr(data);
cout << "初始数组:" << endl;
arr.print();
arr.reverse();
cout << "逆数组:" << endl;
arr.print();
system("pause");
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐