// 旋转数组
void rotateArray(size_t rows, size_t cols, size_t arr[4][4]) {
size_t rotated[rows][cols];
for (size_t i = 0; i < rows; i++) {
for (size_t j = 0; j < cols; j++) {
// rotated[i][j] = a[n - j - 1][i]; // 顺时针翻转
rotated[rows - j - 1][i] = arr[i][j]; // 逆时针翻转
//rotated[j][i] = a[n - j - 1][i]; // 垂直翻转
}
}
memcpy(arr, rotated, sizeof arr[0][0] * rows * cols);
}
打印二维数组
void printAllNumbersInArray(size_t numArr[4][4], int col, int row) {
    for (int i = 0; i < row; i++) {
        for (int j = 0; j < col; j++) {
            int val = numArr[i][j];
            printf("%d \t", val);
        }
        printf("\r");
    }
}测试
int main(int argc, const char * argv[]) {
    size_t numArr[4][4] = {
        {1,  2,  3,  4},
        {5,  6,  7,  8},
        {9,  10, 11, 12},
        {13, 14, 15, 16}
    };
    printf("原始数组:\r\n");
    printAllNumbersInArray(numArr, 4, 4);
    printf("旋转后数组:\r\n");
    rotateArray(4, 4, numArr);
    printAllNumbersInArray(numArr, 4, 4);
    return 0;
}抖音一面面试题
顺时针打印
 

https://www.geeksforgeeks.org/print-a-given-matrix-in-spiral-form/
https://www.codeproject.com/Questions/40918/How-to-print-an-a-4x4-array-in-clockwise-direction
                










