C语言:写一个函数,实现3*3矩阵的转置(指针)

分析:

在主函数 main 中,定义一个 3x3 的整型数组 a,并定义一个指向整型数组的指针 p。然后通过循环结构和 scanf 函数,从标准输入中读取用户输入的 3x3 矩阵的值,并存储到数组 a 中。

接下来,调用 move 函数,传递给它整型数组 a 的地址,即 a 数组的首地址。move 函数的目的是对输入的矩阵进行转置操作,即行列互换。在 move 函数中,使用两重循环遍历数组中的元素,并通过指针操作实现数组元素值的互换,从而实现矩阵的转置。

最后,程序输出转置后的矩阵,同样使用循环和指针操作来访问数组中的元素,并通过 printf 函数将每个元素的值输出到屏幕上。

代码:

复制代码
#include<stdio.h>
void move(int (*p)[3])
{
	int i,j,temp;
    for(i=0;i<3;i++)
	 for(j=0;j<i;j++)
	 {
 		temp=*(*(p+i)+j);
 		*(*(p+i)+j)=*(*(p+j)+i);
 		*(*(p+j)+i)=temp;
 	 }
}
int main()
{
	int a[3][3];
	int (*p)[3],i,j,temp;
	p=a;
	printf("input:\n");
	for(i=0;i<3;i++)
	 for(j=0;j<3;j++)
	 scanf("%d",&a[i][j]);
     move(p);
	 printf("output:\n");
    for(i=0;i<3;i++)
     {
     	for(j=0;j<3;j++)
	    printf("%3d ",*(*(p+i)+j));
     	printf("\n");
     } 
	 return 0; 
}

运行结果:

相关推荐
iCxhust4 小时前
Prj10--8088单板机C语言8259测试(1)
c语言·开发语言
apocelipes8 小时前
Linux c 运行时获取动态库所在路径
linux·c语言·linux编程
int型码农9 小时前
数据结构第八章(一) 插入排序
c语言·数据结构·算法·排序算法·希尔排序
学习噢学个屁12 小时前
基于STM32语音识别柔光台灯
c语言·stm32·单片机·嵌入式硬件·语音识别
XRZaaa17 小时前
常见排序算法详解与C语言实现
c语言·算法·排序算法
jie1889457586618 小时前
C++ 中的 const 知识点详解,c++和c语言区别
java·c语言·c++
彩妙不是菜喵19 小时前
算术操作符与类型转换:从基础到精通
c语言
JKHaaa20 小时前
几种简单的排序算法(C语言)
c语言·算法·排序算法
草莓熊Lotso1 天前
【数据结构初阶】--算法复杂度的深度解析
c语言·开发语言·数据结构·经验分享·笔记·其他·算法
KyollBM1 天前
【CF】Day75——CF (Div. 2) B (数学 + 贪心) + CF 882 (Div. 2) C (01Trie | 区间最大异或和)
c语言·c++·算法