ganmu


私信TA

用户名:dotcpp0726067

访问量:3506

签 名:

等  级
排  名 1522
经  验 2812
参赛次数 0
文章发表 104
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

解题思路:

可通过两种方式求解此题

方式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 人评分

  评论区

  • «
  • »