/*8.10.将一个5x5矩阵中最大的元素放在中心, 四个角分别放4个最小的元素(顺序为从左到右,从上到下依次从小到大排序), 写一个函数实现之,用main函数
求大佬帮忙看一下我这个程序输出时哪里出了问题,运行后结果只输出一行;例如:输入:
1 2 3 4 5
6 7 8 9 10
11 12 13 14 15
16 17 18 19 20
21 22 23 24 25
输出:
1 5 21 13 2
#include <stdio.h>
int main()
{
int fun(int a[][5]);
int a[5][5];
int i, j;
printf("请输入:\n");
for (i = 0; i < 5; i++)
{
for (j = 0; j < 5; j++)
{
scanf_s("%d", &a[i][j]);
}
}
fun(a);
printf("输出:\n");
for (int i = 0; i < 5; i++)
{
for (int j = 0; j < 5; j++)
{
printf("%d ", a[i][j]);
}
printf("\n");
return 0;
}
}
int fun(int a[][5])
{
int exchange(int* p, int* q);
int(*p)[5];
p = a;
int i, j, max, min, k, l, t;
//处理最大的数;
max = *(*(p + 0) + 0);
for (i = 0; i < 5; i++)
{
for (j = 0; j < 5; j++)
{
if (*(*(p + i) + j) > max)
{
max = *(*(p + i) + j);
k = i;
l = j;
}
}
}
exchange(*(p + 2) + 2, *(p + k) + l);
//处理最小值;
min = *(*(p + 0) + 0);
k = 0;
l = 0;
for (i = 0; i < 5; i++)
{
for (j = 0; j < 5; j++)
{
if (*(*(p + i) + j) < min)
{
min = *(*(p + i) + j);
k = i;
l = j;
}
}
}
exchange(*(p + 0) + 0, *(p + k) + l);
//处理第二小值;
min = *(*(p + 0) + 1);
k = 0;
l = 1;
for (i = 0; i < 5; i++)
{
for (j = 0; j < 5; j++)
{
if (i == 0 && j == 0) continue;
if (*(*(p + i) + j) < min)
{
min = *(*(p + i) + j);
k = i;
l = j;
}
}
}
exchange(*(p + 0) + 4, *(p + k) + l);
//处理第三小值;
min = *(*(p + 0) + 1);
k = 0;
l = 1;
for (i = 0; i < 5; i++)
{
for (j = 0; j < 5; j++)
{
if (i == 0 && j == 0) continue;
if (i == 0 && j == 4) continue;
if (*(*(p + i) + j) < min)
{
min = *(*(p + i) + j);
k = i;
l = j;
}
}
}
exchange(*(p + 4) + 0, *(p + k) + l);
//处理第四小值;
min = *(*(p + 0) + 1);
k = 0;
l = 1;
for (i = 0; i < 5; i++)
{
for (j = 0; j < 5; j++)
{
if (i == 0 && j == 0) continue;
if (i == 0 && j == 4) continue;
if (i == 4 && j == 0) continue;
if (*(*(p + i) + j) < min)
{
min = *(*(p + i) + j);
k = i;
l = j;
}
}
}
exchange(*(p + 4) + 4, *(p + k) + l);
return 0;
}
int exchange(int* p, int* q)
{
int t=0;
t = *p;
*p = *q;
*q = t;
return 0;
}