#include <iostream> using namespace std; // 函数rotateLeft:矩阵循环左移 // 参数:a-100*100的二维数组,用来存储n行n列的数组(n<100),存储在其~n-1行和~n-1列, // m-循环左移的位数(0<m<n) // 返回值:无,循环左移的结果写入原二维数组中 // 说明:传递多维数组时,形式参数中,除了第一维外,其它维的大小必须给出 // 方便编译器计算每个数组元素的地址 void rotateLeft(int a[][100],int n,int m); int main() { int a[100][100]; // 定义存储二维数组的空间 int n, m; cin >> n >> m; // 输入n和m // 输入n*n的矩阵,存储在数组a的~n-1行和~n-1列 int i, j; for(i = 0; i < n; i++) for(j = 0; j < n; j++) cin >> a[i][j]; // 循环左移 // 说明:传递多维数组时,实在参数只需要给出数组名就可以了 rotateLeft(a,n,m); // 输出循环右移的结果 for(i = 0; i < n; i++){ for(j = 0; j < n; j++) cout << " " << a[i][j]; cout << endl; } return 0; }补充函数 rotateLeft,该函数实现对一个n×n方阵中的每个元素循环向左移m个位置(0<m<n),即将第0、1、…… 、n−1列变换为第n−m、n−m+1、…… 、n−1、0、1、…… 、n−m−1列。
时间: 2024-01-08 21:03:03 浏览: 32
void rotateLeft(int a[][100], int n, int m) {
// 计算需要移动的列数
int move = m % n;
// 对每一行进行循环左移
for (int i = 0; i < n; i++) {
// 将前move列保存到临时数组中
int temp[100];
for (int j = 0; j < move; j++) {
temp[j] = a[i][j];
}
// 将第move列至最后一列依次向前移动move列
for (int j = move; j < n; j++) {
a[i][j - move] = a[i][j];
}
// 将临时数组中保存的前move列加到最后
for (int j = n - move; j < n; j++) {
a[i][j] = temp[j - n + move];
}
}
}
相关问题
#include <iostream> #include <fstream> #include <vector> #include <string> using namespace std; //
这是一段C++程序的头文件部分,包含了一些标准库的头文件,具体介绍如下:
1. iostream:提供了输入输出流的基本功能,如cin、cout等。
2. fstream:提供了文件操作相关的功能,如读写文件等。
3. vector:提供了可变大小数组的功能,可以方便地进行动态管理。
4. string:提供了字符串相关的功能,如字符串的拼接、截取等。
其中,using namespace std; 表示使用标准命名空间,可以简化程序中的代码。
#include <iostream> #include <vector> #include <fstream> using namespace std; #include <boost/timer.hpp>
这段代码是一个C++程序的头文件部分,它包含了三个标准库的头文件和一个boost库的头文件。具体介绍如下:
1. `#include <iostream>`:这是C++标准库中的头文件,用于输入输出操作。它包含了一些常用的输入输出流对象,如`cin`和`cout`。
2. `#include <vector>`:这是C++标准库中的头文件,用于定义和操作动态数组(向量)。`vector`是一个模板类,可以存储任意类型的元素,并提供了方便的方法来访问和修改这些元素。
3. `#include <fstream>`:这是C++标准库中的头文件,用于文件输入输出操作。它提供了一些类和函数,可以方便地读写文件。
4. `#include <boost/timer.hpp>`:这是boost库中的头文件,用于计时器功能。boost是一个流行的C++扩展库,提供了许多高效且易于使用的功能和工具。