解题思路:
可通过两种方式求解此题
方式1:通过观察得知,此九宫格二维数组只有6个数需要调换,即2和4,3和7,6和8,故只需要用swap函数两两一组调换3次即可
方式2:设一个中间数组用于接收初始数组,把初始数组的列放到中间数组的行上即可。例:a[i][j]=b[j][i]
注意事项:
无
参考代码:
//方法1:
#include<iostream>
using namespace std;
void dfs()
{
int a[3][3];
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
cin >> a[i][j];
}
}
swap(a[0][1], a[1][0]);
swap(a[0][2], a[2][0]);
swap(a[1][2], a[2][1]);
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
cout << a[i][j] << " ";
}
cout << endl;
}
}
int main()
{
dfs();
return 0;
}
//方法2:
#include<iostream>
using namespace std;
void dfs()
{
int a[3][3];
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
cin >> a[i][j];
}
}
int b[3][3];
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
b[j][i]= a[i][j];
}
}
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3;j++)
{
cout << b[i][j] << " ";
}
cout << endl;
}
}
int main()
{
dfs();
return 0;
}
0.0分
0 人评分