写一个函数,使给定的一个3X3的二维整型数组转置,即行列互换。
void reverse(int arr1[][3],int arr2[][10]) { for (int i = 0; i < 3; i++) { for (int j = 0; j < 3;j++) { arr2[j][i] = arr1[i][j]; } } for (int i = 0; i < 3;i++) { for (int j = 0; j < 3;j++) { printf("%d ",arr2[i][j]); } printf("\n"); } } int main() { int arr1[3][3] = { 1,2,3,4,5,6,7,8,9 }; int arr2[10][10] = { 0 }; reverse(arr1,arr2); return 0; }
1
#include <stdio.h> // 3x3 矩阵转置函数 void transposeMatrix(int matrix[3][3]) { int temp; // 只遍历上三角部分进行转置(避免重复交换) for (int i = 0; i < 3; i++) { for (int j = i + 1; j < 3; j++) { // 交换 matrix[i][j] 和 matrix[j][i] temp = matrix[i][j]; matrix[i][j] = matrix[j][i]; matrix[j][i] = temp; } } } // 打印矩阵 void printMatrix(int matrix[3][3]) { for (int i = 0; i < 3; i++) { for (int j = 0; j < 3; j++) { printf("%d ", matrix[i][j]); } printf("\n"); } } int main() { // 初始化 3x3 矩阵 int matrix[3][3] = { {1, 2, 3}, {4, 5, 6}, {7, 8, 9} }; printf("原矩阵:\n"); printMatrix(matrix); // 转置矩阵 transposeMatrix(matrix); printf("\n转置后的矩阵:\n"); printMatrix(matrix); return 0; }
#include <stdio.h> #include<stdlib.h> #include<string.h> #include<math.h> #define N 3 int main(void) {
int a[N][N]={1,2,3,4,5,6,7,8,9}, b[N][N];//转置前 转置后 puts("转置前"); for (int i = 0; i < N; i++) {//行 for (int j= 0; j < N; j++) {//列 printf("%d ", a[i][j]); } printf("\n"); } for (int i = 0; i < N; i++) { for (int j = 0; j < N; j++) { b[i][j] = a[j][i]; } printf("\n"); } puts("转置后"); for (int i = 0; i < N; i++) { for (int j = 0; j < N; j++) { printf("%d ", b[i][j]); } printf("\n"); } return 0; }
题目解析:
进行数组的行列互...
登录后提交答案