解题思路和注意事项:


思路很简单,正常输入,输出的时候将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 条评论

每天至少八杯水 3年前 回复TA
题目要求是重新写一个函数您的程序明显不合题意#include <stdio.h> 
void prime(int a[3][3]);
int main()
{
	int j,i,a[3][3];
	for(i=0;i<3;i++)
	{    
		for(j=0;j<3;j++)
		{
		scanf("%d",&a[i][j]);	
		}	
	}
prime(a);
	return 0;
}

void prime(int a[3][3])
{
	int i,j;
	for(i=0;i<3;i++)
	{
		for(j=0;j<3;j++)
		{
		printf("%d ",a[j][i]);
		}
		printf("\n");
	}	
}
kan2er 4年前 回复TA
@煮酒老麦 龟龟,返璞归真了。哈哈哈
花开若相惜 4年前 回复TA
@煮酒老麦 这个能过吗?
踏上星辰 4年前 回复TA
很好的思路,学到了。只注意去考虑对角线上的数去了
踏上星辰 4年前 回复TA
@煮酒老麦 你可太秀了哈哈
专抢小情绪 4年前 回复TA
@煮酒老麦 我就知道有这个!!!
lebron 4年前 回复TA
@a成成成 666
a成成成 4年前 回复TA
@a成成成 不改变原来数组的内容,只是改变其输出方式。
a成成成 4年前 回复TA
很好。
当当当 4年前 回复TA
@当当当 a的每一行等于b的每一列,