标题:/*8.10.将一个5x5矩阵中最大的元素放在中心, 四个角分别放4个最小的元素(顺 ...
取消只看楼主
jiqiunianri
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2020-12-27
结帖率:0
已结贴  问题点数:20 回复次数:0 
/*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;
}
搜索更多相关主题的帖子: int exchange i++ min for 
2020-12-27 17:37



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-504408-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.240295 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved