解题思路和注意事项:


思路很简单,正常输入,输出的时候将i和j的位置换一下就好了


原理是数组的第一个下标先开始递增,输出的就是第一行的数其实就是原本的列。

参考代码:

#include<stdio.h>
int main()
{
	int a[3][3],i,j;
	for(i=0; i<3; i++){
		for(j=0; j<3; j++){
			scanf("%d",&a[i][j]);
		}
	}
	for(i=0; i<3; i++){
		for(j=0; j<3; j++){
			printf("%d ",a[j][i]);
		}
		printf("\n");
	}
	return 0;
}


点赞(9)
 

0.0分

80 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 49 条评论

chenxizhan 5年前 回复TA
妙啊
qweuihqqi 5年前 回复TA
用函数的#include<stdio.h>
void xtoy(int b[3][3])
{
	int a[3][3], i, j;
	for (i = 0; i < 3; i++)
	{
		for (j = 0; j < 3; j++)
		{
			
			printf("%d ", b[j][i]);
			if (j == 2)
			{
				printf("\n");
			}
		}
	}
}
int main()
{
	int a[3][3], i, j;
	for (i = 0; i < 3; i++)
	{
		for (j = 0; j < 3; j++)
		{
			scanf("%d", &a[i][j]);
		}
	}
	xtoy(a);
}
加油鸭 5年前 回复TA
#include <stdio.h>

int main(void) {

	int arr[3][3];
	int i, j, temp = 0;
	for (i = 0; i < 3; i++) {
		for (j = 0; j < 3; j++) {
			scanf("%d", &arr[i][j]);
		}
	}
	for (i = 0; i < 3; i++) {
		for (j = 0; j < 3; j++) {
			if (i == j) break;
			temp = arr[i][j];
			arr[i][j] = arr[j][i];
			arr[j][i] = temp;
		}
	}
	for (i = 0; i < 3; i++) {
		for (j = 0; j < 3; j++) {
			printf("%d ", arr[i][j]);
		}
		printf("\n");
	}

}
小白到大神 5年前 回复TA
#include <stdio.h>

void fun(int a[][3])
{
    int i, j;

    for(i = 0; i < 3; i++)
    {
        for(j = 0; j < 3; j++)
            printf("%-2d", a[j][i]);
        printf("\n");
    }
}

int main(void)
{
    int a[3][3];
    int i, j;

    for(i = 0; i < 3; i++)
    {
        for(j = 0; j < 3; j++)
            scanf("%d", &a[i][j]);
    }

    fun(a);

    return 0;

}
贴个自己的
一叶知秋 5年前 回复TA
#include <stdio.h>

#define X 3
#define Y 3

void change ( int a[][Y] , int len );

int main()
{
  int a[X][Y];
  int i=0, j=0;
  for( i = 0  ; i < X ; i++ ){
    for ( j = 0 ; j < Y ; j++ ){
     scanf("%d",&a[i][j]);
    }
  }

  change( a, X);

  return 0;
}

void change ( int a[][Y] , int len ){
  int i,j;

  for( i = 0  ; i < len ; i++ ){
    for ( j = 0 ; j < len ; j++ ){
      printf("%d ",a[j][i]);
    }
    putchar('\n');
  }
}
qianwen 6年前 回复TA
@Solotravel @huodongquan 感谢
Solotravel 6年前 回复TA
@小兔子 把元素当成一个个变量,比如:有两个变量a、b要交换数值,若a=1,b=2,那么,a+=b就是a=a+b=3,b=a-b=3-2=1,a=a-b=3-1=2,这样数值就交换过来了。
Solotravel 6年前 回复TA
@Solotravel @qianwenzhang 在数组中就是行列互换,如a[1][2]跟a[2][1]对换,加判断条件i<j就是避免重复对换,就是避免换过来之后又换回去。
Solotravel 6年前 回复TA
@Solotravel @qianwenzhang 比如:有两个变量a、b,a=1,b=2;那么,a+=b就是a=a+b=3,b=a-b=3-2=1,a=a-b=3-1=2,这样数值就交换过来了。
Solotravel 6年前 回复TA
@Solotravel @qianwenzhang 就是两个变量交换数值的意思,利用“加减法”。