Linux下的C语言编程——指针实现矩阵转置

今天我刚刚学习了指针,对它掌握的并不是很了解。现在我们来写一个通过指针来实现矩阵转置的程序。原先在学习数组的时候,我曾经练习过通过数组来实现矩阵转置。

矩阵转置的核心是如何交换a[i][j]和a[j][i]的值。下面我先附上我原先写的代码,大家可以看一下。

#include<stdio.h>

void transpos(int arr[4][4])
{
	int i;
	int j;
	int temp;

	for(i = 0; i < 4; i++)
	{
		for(j = i+1; j < 4; j++ )
		{
			temp = arr[i][j];
			arr[i][j] = arr[j][i];
			arr[j][i] = temp;
		}
	}

	for(i = 0; i < 4; i++)
	{
		for(j = 0; j < 4; j++)
		{
			if(j%4 == 0)
				printf("\n");
			printf("%4d",arr[i][j]);
		}
	}
	printf("\n");
}

int main()
{
	int arr[4][4];
	int i;
	int j;

	printf("please input the arry!\n");

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

	for(i = 0; i < 4; i++)
		for(j = 0; j < 4; j++)
		{
			if(j%4 == 0)
				printf("\n");

			printf("%4d",arr[i][j]);
		}

	printf("\n");

	transpos(arr);
}

这是我原先写的代码,现在我再附上我用指针实现数组转置的代码

#include <stdio.h>

void move(int *p)
{
	int i;
	int j;
	int t;
	
	for (i = 0; i < 3; i++)
		        
		for (j = i; j < 3; j++)
		{
			t=*(p + 3*i + j);
			*(p + 3*i+j) = *(p + 3*j + i);
			*(p + 3*j + i) = t;
		}
						   
}

int main()
{
	int a[3][3];
	int *p;
	int i;

	printf("please input the matrix!\n");

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

	 for(i = 0; i < 3; i++)
	 {
		 printf("%d %d %d\n",a[i][0],a[i][1],a[i][2]);
	 }
	 p=&a[0][0];
	 move(p);
	 printf("Now,matrix:\n");

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


    return 0;
}

两个程序很相似,下面我附上运行图



  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值