鱼C论坛

 找回密码
 立即注册
查看: 1334|回复: 2

[已解决]c语言求助

[复制链接]
发表于 2023-5-9 16:21:10 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
从键盘输入整数n(2<n<10)的值,输入一个二维整型数组(n×n)。对该二维数组所构成的矩阵进行主对角线和次对角线元素的位置进行交换,输出变换后的数组。

【样例输入】

4

3 5 6 7

8 5 6 2

4 6 2 1

9 6 8 3

【样例输出】

7 5 6 3

8 6 5 2

4 2 6 1

3 6 8 9
#include <stdio.h>
int main()
{
    int n,temp;
    scanf("%d",&n);
    int i,j,a[n][n];
    for(i=0;i<n;i++)
    {
        for(j=0;j<n;j++)
        {
            scanf("%d",&a[i][j]);
        }
    }
    for(i=0;i<n;i++)
    {
        for(j=0;j<n;j++)
        {
                temp=a[i][n-i-1];
                a[i][n-i-1]=a[i][i];
                a[i][i]=temp;

        }
    }
    for(i=0;i<n;i++)
    {
        for(j=0;j<n;j++)
        {
            printf("%d ",a[i][j]);
        }
        printf("\n");
    }
    return 0;
}
这个为什么不对啊
最佳答案
2023-5-9 16:21:52
你的代码中只进行了主对角线元素和次对角线元素的交换,而没有进行主对角线和次对角线的交换。所以你需要再添加一次循环,将主对角线和次对角线的元素进行交换。具体代码如下:
#include <stdio.h>

int main()
{
    int n, temp;
    scanf("%d", &n);
    int i, j, a[n][n];
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            scanf("%d", &a[i][j]);
        }
    }
    for (i = 0; i < n; i++)
    {
        temp = a[i][i];
        a[i][i] = a[i][n - i - 1];
        a[i][n - i - 1] = temp;
    }
    for (i = 0; i < n / 2; i++)
    {
        for (j = 0; j < n; j++)
        {
            temp = a[i][j];
            a[i][j] = a[n - i - 1][n - j - 1];
            a[n - i - 1][n - j - 1] = temp;
        }
    }
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            printf("%d ", a[i][j]);
        }
        printf("\n");
    }
    return 0;
}


这个代码中,我们首先对主对角线和次对角线的元素进行了交换,然后再对主对角线和次对角线进行了交换,即将第 i 行和第 n-i-1 行进行交换。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-5-9 16:21:52 | 显示全部楼层    本楼为最佳答案   
你的代码中只进行了主对角线元素和次对角线元素的交换,而没有进行主对角线和次对角线的交换。所以你需要再添加一次循环,将主对角线和次对角线的元素进行交换。具体代码如下:
#include <stdio.h>

int main()
{
    int n, temp;
    scanf("%d", &n);
    int i, j, a[n][n];
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            scanf("%d", &a[i][j]);
        }
    }
    for (i = 0; i < n; i++)
    {
        temp = a[i][i];
        a[i][i] = a[i][n - i - 1];
        a[i][n - i - 1] = temp;
    }
    for (i = 0; i < n / 2; i++)
    {
        for (j = 0; j < n; j++)
        {
            temp = a[i][j];
            a[i][j] = a[n - i - 1][n - j - 1];
            a[n - i - 1][n - j - 1] = temp;
        }
    }
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            printf("%d ", a[i][j]);
        }
        printf("\n");
    }
    return 0;
}


这个代码中,我们首先对主对角线和次对角线的元素进行了交换,然后再对主对角线和次对角线进行了交换,即将第 i 行和第 n-i-1 行进行交换。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-5-9 18:36:02 | 显示全部楼层
你的代码有一个问题,它只是循环了 n 次,每次都对当前这一行的主对角线和次对角线上的元素进行交换,但并没有对所有行进行交换,因此不能得到正确的结果。下面给出正确的代码实现:
#include <stdio.h>

int main() {
    int n;
    scanf("%d", &n);
    int matrix[n][n];
    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < n; ++j) {
            scanf("%d", &matrix[i][j]);
        }
    }
    // 对主对角线上的元素进行交换
    for (int i = 0; i < n; ++i) {
        int temp = matrix[i][i];
        matrix[i][i] = matrix[n - i - 1][n - i - 1];
        matrix[n - i - 1][n - i - 1] = temp;
    }
    // 对次对角线上的元素进行交换
    for (int i = 0; i < n; ++i) {
        int temp = matrix[i][n - i - 1];
        matrix[i][n - i - 1] = matrix[n - i - 1][i];
        matrix[n - i - 1][i] = temp;
    }
    // 输出变换后的矩阵
    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < n; ++j) {
            printf("%d ", matrix[i][j]);
        }
        printf("\n");
    }
    return 0;
}
该代码的原理与你的代码类似,但它循环了所有的行,依次对每一行的主对角线和次对角线上的元素进行交换。这样才能得到正确的结果。
有用请设置最佳答案
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-24 13:40

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表