标题:/*8.10.将一个5x5矩阵中最大的元素放在中心, 四个角分别放4个最小的元素(顺 ...
只看楼主
jiqiunianri
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2020-12-27
结帖率:0
已结贴  问题点数:20 回复次数:2 
/*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
apull
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:三体星系
等 级:版主
威 望:185
帖 子:1404
专家分:8479
注 册:2010-3-16
得分:10 
main里的return 0放错地方了。
输出建议用printf("%2d ", a[i][j]);,比较清晰些
2020-12-27 20:47
风过无痕1989
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:8
帖 子:228
专家分:1050
注 册:2020-7-17
得分:10 
回复 楼主 jiqiunianri
按照2楼的修改,你的程序就没有问题了。我按照题目的意思,也写了一个,只是输入是随意的25个数,输出是个二维数组。纯属凑个热闹(既是凑热闹,本意是将处理部分写成函数的,也就不写了):
程序代码:
#include <stdio.h>
int main()
{
    int sort(int *p,int n);
    int a[5][5];
    int b[25];
    int i, j, k = 25;
    int temp1, temp2, temp3, temp4;
    printf("请输入:\n");
    for (i = 0; i < 5; i++)
    {
        for (j = 0; j < 5; j++)
        {
            scanf_s("%d", &a[i][j]);
            b[k] = a[i][j];
            k++;
        }
    }

    sort(b,k);

    temp1 = b[1];
    temp2 = b[2];
    temp3 = b[3];
    temp4 = b[24];

    for (j = 1; j < 4; j++)    // 处理第 0 行
    {
        b[j] = b[j + 3];
    }
    b[4] = temp1;

    for (j = 5; j < 12; j++)   // 处理第 1 行及第 2 行前半
    {
        b[j] = b[j + 2];
    }
    b[12] = temp4;

    for (j = 13; j < 20; j++)   // 处理第 2 行后半第 3 行
    {
        b[j] = b[j + 2];
    }
    b[20] = temp2;

    for (j = 21; j < 24; j++)   // 处理第 4 行
    {
        b[j] = b[j + 1];
    }
    b[24] = temp3;

    k = 0;
    for (i = 0; i < 5; i++)    // 一维数组转二维数组
    {
        for (int j = 0; j < 5; j++)
        {
            a[i][j] = b[k];
            k++;
        }
    }

    for (i = 0; i < 5; i++)    // 输出数组
    {
        for (int j = 0; j < 5; j++)
        {
            printf("%2d ", a[i][j]);
        }
        printf("\n");
    }
    return 0;
}

int sort(int *p,int n)            // 对一维数 b 组排序
{
    int i, j, temp;
    for (i = 0;i < n;i++)
    {
        for (j = 0;j < n - 1;j++)
        {
            if (*(p + j) > *(p + j + 1))
            {
                temp = *(p + j);
                *(p + j) = *(p + j + 1);
                *(p + j + 1) = temp;
            }
        }
    }
    return 0;
}


[此贴子已经被作者于2020-12-28 11:30编辑过]

2020-12-28 11:27



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




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

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