用C语言编写函数 rotateLeft,该函数实现对一个n×n方阵中的每个元素循环向左移m个位置(0<m<n),即将第0、1、…… 、n−1列变换为第n−m、n−m+1、…… 、n−1、0、1、…… 、n−m−1列。
时间: 2024-05-10 13:18:20 浏览: 75
C语言数组元素循环右移问题及解决方法
5星 · 资源好评率100%
以下是用C语言编写的rotateLeft函数的代码实现:
```c
void rotateLeft(int n, int m, int matrix[][n]) {
int temp[m][n];
for (int i = 0; i < m; i++) {
for (int j = 0; j < n; j++) {
temp[i][j] = matrix[i][j];
}
}
for (int i = 0; i < n - m; i++) {
for (int j = 0; j < n; j++) {
matrix[i][j] = matrix[i + m][j];
}
}
for (int i = n - m; i < n; i++) {
for (int j = 0; j < n; j++) {
matrix[i][j] = temp[i - (n - m)][j];
}
}
}
```
该函数接收三个参数:方阵的大小n、移动的步数m和存储方阵元素的二维数组matrix。首先,我们需要创建一个临时的m×n的矩阵temp,将原来的前m列复制到temp中。之后,我们将matrix中的前n-m列向左移动m个位置,即将第i列变换为第i+m列。最后,将temp中的m列复制回matrix的后n-m列即可。
需要注意的是,在C语言中,二维数组的第一维必须是常量,因此我们需要将方阵的大小n作为函数参数传递,并在二维数组定义时使用变量n来声明列数。
阅读全文