标题:【Dev-C++】中【函数原型】是否无法 定义【变长二维数组】(附【源代码】)
只看楼主
了无此生
Rank: 3Rank: 3
来 自:粤地潮州
等 级:论坛游侠
威 望:3
帖 子:82
专家分:121
注 册:2018-11-14
结帖率:100%
已结贴  问题点数:40 回复次数:2 
【Dev-C++】中【函数原型】是否无法 定义【变长二维数组】(附【源代码】)
我用Dev-C++写这个程序时,发现编译出错,而使用学校的服务器则可以编译运行
求大佬们指点一下
程序代码:
#include <stdio.h>

void create_magic_square(int n, char magic_square[n][n]);            //这个程序在 Dev-C++ 上编译错误
void print_magic_square(int n, char magic_square[n][n]);

int main(void)
{    
    int n;
    printf("This is program creates a magic square of a specified size.\n");
    printf("The size must be an odd number between 1 and 99.\n");
    printf("Enter size of magic square: ");
    
    scanf("%d", &n);
    
    char a[n][n];                //变长数组无法直接 a[i][j] = {0}; 
    
    create_magic_square(n, a);
    
    print_magic_square(n, a);
    
    return 0;

 } 

 

 void create_magic_square(int n, char magic_square[n][n])

 {
     int num = 1, i, j;
     
     for (i = 0; i < n; i++)
        for (j = 0; j < n; j++)
            magic_square[i][j] = 0;                //清零,为后面替换做准备; 
    
    i = 0, j = n / 2;                        //开始的地方; 
     
    while (num <= n * n) {                        //当 num < n * n 时, 循环下去;  
        if (magic_square[i][j] == 0) {                //当数组元素未被填入非零数字时替换; 
            magic_square[i][j] = num++;
            i = (i - 1 + n) % n, j = (j + 1) % n;        //当要用函数替换这个语句时,发现一个函数无法返回两个值,所以最后放弃用函数; 
        }
        else {                            //当数组元素已被替换时下跑到前一个元素的下面,并继续执行斜向上替换直至结束; 
            i = (i + 2) % n, j = (j - 1 + n) % n; 
            magic_square[i][j] = num++;
            i = (i - 1 + n) % n, j = (j + 1) % n;
        }
    }

 }

 

 void print_magic_square (int n, char magic_square[n][n])

 {
     for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++)
            printf("%5d", magic_square[i][j]);
        putchar('\n');
    }
}
搜索更多相关主题的帖子: C++ 函数 void int num 
2019-01-12 01:45
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:20 
char a[n][n]; CPP应该无问题
void create_magic_square(int n, char magic_square[n][n]); 传数组首元素地址和维数就可以
void create_magic_square(int n, char *magic_square);
2019-01-12 05:07
wp231957
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:神界
等 级:版主
威 望:422
帖 子:13681
专家分:53296
注 册:2012-10-18
得分:20 
有一部分编译器不支持变长数组

DO IT YOURSELF !
2019-01-12 11:18



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




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

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