将一个5x5的矩阵中最大的元素放在中心,4个角分别放4个最小的元素(顺序为从左到右,从上倒下依次从小到大存放),写一函数实现它!
#include<stdio.h>
int main()
{
void change(int *);
int *p,i,j,a[5][5];
printf("please input matrix:/n");
for(i=0;i<5;i++)
for(j=0;j<5;j++)
scanf("%d",&a[i][j]);
p=&a[0][0];
change(p);
printf("the output matrix:/n");
for(i=0;i<5;i++)
{for(j=0;j<5;j++)
printf("%4d",a[i][j]);
printf("/n");
}
return 0;
}
void change(int *p)
{
int i,temp,j;
int *pmin,*pmax;
pmin=p;//最小的值指向p;
pmax=p;//最大的值指向p;
for(i=0;i<5;i++)
for(j=i;j<5;j++)//j应该等于i;而不是0;按照行来比较,先是比较第0行0列,0行1列,0行2列;0行3列,0行4列;
{
if(*pmin>*(p+5*i+j)) pmin=p+5*i+j;//不能赋值*pmin=*(p+5*i+j),因为这是指针移动到最小值!并且记录pmin位置;
if(*pmax<*(p+5*i+j)) pmax=p+5*i+j;//不能赋值*pmax=*(p+5*i+j),因为这是指针移动到最大值!并且记录pmax位置;
}
temp=*(p+12);//将*(p+12)的值保存到temp;(p+12)是该矩阵的中心元素;序号从0算起;
*(p+12)=*pmax;//将最大值赋值给中心元素;
*pmax=temp;//将保存的值写入到*pmax中,此时pmax值等于p+5*i+j;
temp=*p;
*p=*pmin;
*pmin=temp;//将保存的值写入到*pmin中,此时pmin值等于p+5*i+j;
pmin=p+1;//*p已经比较过的,不需要在比较所以指针加一!
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(((p+5*i+j)!=p)&&(*pmin>*(p+5*i+j))) //排除第一个最小的数的地址指针!比较其他数的最小值!
pmin=p+5*i+j;//不能*pmin=*(p+5*i+j)赋值,在此的意思是指针移动到最小位置;
//*(p+4)=*pmin;
//*pmin=temp;
temp=*pmin;
*pmin=*(p+4);//此时pmin=p+1;此时存放交换的数据;
*(p+4)=temp;
pmin=p+1;//*(p+4)已经比较过的,不需要在比较所以指针加一!
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(((p+5*i+j)!=p)&&((p+5*i+j)!=(p+4))&&(*pmin>*(p+5*i+j)))
pmin=p+5*i+j;//不能*pmin=*(p+5*i+j)赋值,在此的意思是指针移动到最小位置;
//temp=*(p+20);
//*(p+20)=*pmin;
//*pmin=temp;
temp=*pmin;
*pmin=*(p+20);//此时pmin=p+1;此时存放交换的数据;
*(p+20)=temp;
pmin=p+1;//*(p+20)已经比较过的,不需要在比较所以指针加一!
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(((p+5*i+j)!=p)&&((p+5*i+j)!=(p+4))&&((p+5*i+j)!=(p+20))&&(*pmin>*(p+5*i+j)))
pmin=p+5*i+j;//不能*pmin=*(p+5*i+j)赋值,在此的意思是指针移动到最小位置;
//temp=*(p+24);
//*(p+24)=*pmin;
//*pmin=temp;
temp=*pmin;
*pmin=*(p+24);//此时pmin=p+1;此时存放交换的数据;
*(p+24)=temp;
}