利用指標傳遞二維陣列進行行列式轉置
阿新 • • 發佈:2019-01-30
#include <stdio.h>
#include <stdlib.h>
void input(int *pa,int n)
{
int i;
for(i=0;i<n;i++,pa++)
scanf("%d",pa);
}
void output(int *pa,int n)
{
int i;
for(i=0;i<n;i++,pa++)
{
printf("%d ",*pa);
if((i+1)%3==0) printf("\n");
}
}
void trans(int (*pa)[3],int row,int col)//掃描一個上或下三角就行
{
int i,j,t;
for(i=0;i<row;i++)
{
for(j=0;j<i;j++)
{
t=*(*(pa+i)+j);//t=pa[i][j];
*(*(pa+i)+j)=*(*(pa+j)+i);//pa[i][j]=pa[j][i];
*(*(pa+j)+i)=t;//pa[j][i]=t;
}
}
}
int main()
{
int a[3][3],n=9;
input(a[0],n);//*a,&a[0][0];
trans(a,3,3);
output(a[0],n);
return 0;
}
#include <stdlib.h>
void input(int *pa,int n)
{
int i;
for(i=0;i<n;i++,pa++)
scanf("%d",pa);
}
void output(int *pa,int n)
{
int i;
for(i=0;i<n;i++,pa++)
{
printf("%d ",*pa);
if((i+1)%3==0) printf("\n");
}
}
void trans(int (*pa)[3],int row,int col)//掃描一個上或下三角就行
{
int i,j,t;
for(i=0;i<row;i++)
{
for(j=0;j<i;j++)
{
t=*(*(pa+i)+j);//t=pa[i][j];
*(*(pa+i)+j)=*(*(pa+j)+i);//pa[i][j]=pa[j][i];
*(*(pa+j)+i)=t;//pa[j][i]=t;
}
}
}
int main()
{
int a[3][3],n=9;
input(a[0],n);//*a,&a[0][0];
trans(a,3,3);
output(a[0],n);
return 0;
}