5x5矩阵调整大小位置!

本文介绍了一个C语言函数,该函数接收一个5x5的矩阵,并将其最大元素移至中心,四个角落则放置四个最小元素(从左到右、从上到下递增)。通过指针操作实现了矩阵元素的重新排列。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

将一个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;
  
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值