判断矩阵是否是魔方矩阵

给定程序中,函数fun的功能是:判定形参a所指的NxN(规定N为奇数)的矩阵是否是"魔方",若是,函数返回值为1;不是,函数返回值为0。"幻方"的判定条件是:矩阵每行、每列、主对角线及反对角线上元素之和都相等。

例如,以下3x3的矩阵就是一个"魔方":

4 9 2

3 5 7

8 1 6

c 复制代码
#include <stdio.h>
#include <stdlib.h>
#define N 3

int fun(int (*a)[N])
{
    int i, j, m1, m2, row, colum;
    m1 = m2 = 0;
    for (i = 0; i < N; i++)
    {
        j = N - i - 1;
        m1 += a[i][i];
        m2 += a[i][j];
    }
    if (m1 != m2)
    {
        return 0;
    }
    for (i = 0; i < N; i++)
    {
        row = colum = 0; // Initialize row and colum to 0
        for (j = 0; j < N; j++)
        {
            row += a[i][j];
            colum += a[j][i];
        }
        if ((row != colum) || (row != m1))
        { // Fix logical condition
            return 0;
        }
    }
    return 1; // Fix return value
}

int main()
{
    int x[N][N], i, j;
    printf("输入一个3×3的矩阵:\n");
    for (i = 0; i < N; i++)
    {
        for (j = 0; j < N; j++)
        {
            scanf("%d", &x[i][j]);
        }
    }
    if (fun(x))
    {
        printf("这个矩阵是幻方\n");
    }
    else
    {
        printf("这个矩阵不是幻方\n");
    }
    system("pause");
    return 0;
}

函数fun通过计算矩阵的对角线和反角线,以及计算每行和每列的元素之和,来判断是否满足魔方的条件。具体来说:

  • 使用变量m1和m2来分别记录主对角线和反角线上的元素之和。
  • 遍历主对角线和反角线,将对应位置的元素加到m1和m2中。
  • 如果m1又m2不一致,说明不是魔方,直接返回0。
  • 遍历每行和每列,将元素之和与第一行的元素之和(m1)进行比较,如果不成立,说明不是魔方,返回0。
  • 如果以上条件都满足,函数返回1,表示矩阵是魔方。
  • 在main函数中,用户输入一个3×3的矩阵,然后调用fun函数判断是否是魔方,并输出相应的结果。
相关推荐
Cx330❀31 分钟前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
..过云雨2 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习
谱写秋天3 小时前
在STM32F103上进行FreeRTOS移植和配置(STM32CubeIDE)
c语言·stm32·单片机·freertos
我不是板神3 小时前
程序设计|C语言教学——C语言基础2:计算与控制语句
c语言
基于python的毕设3 小时前
C语言栈的实现
linux·c语言·ubuntu
promising-w8 小时前
【嵌入式C语言】六
c语言·开发语言
ankleless8 小时前
C语言(11)—— 数组(超绝详细总结)
c语言·零基础·数组·二维数组·自学·一维数组
草莓熊Lotso9 小时前
《吃透 C++ 类和对象(中):const 成员函数与取地址运算符重载解析》
c语言·开发语言·c++·笔记·其他
野生的编程萌新12 小时前
从冒泡到快速排序:探索经典排序算法的奥秘(二)
c语言·开发语言·数据结构·c++·算法·排序算法
谱写秋天1 天前
FreeRTOS中断服务程序(ISR)详细讲解
c语言·freertos·isr