Проблема с вводом массива - PullRequest
0 голосов
/ 29 апреля 2011

Так вот мой код:

#include <stdio.h>
#include <ctype.h>
#include <stdlib.h>
#define MAX n
int t,n;
int readtime ();
int readboardsize();
void readboard(int board[MAX][MAX], int n);
void printboard(int board[MAX][MAX]);

int main(int argc, char * argv[]){
    int board[MAX][MAX]; 
    t = readtime();
    n = readboardsize();
    printf("%d\n",n);
    readboard(board,n);
    printboard(board);
 return 0;

}

int readtime() {
    int nvr, scannedt;

    printf("Enter t :");
    nvr = scanf("%d",&scannedt);
    if (scannedt>1000 || scannedt<0 || nvr==0) {
        printf("Incorrect input: t must be 0..1000\n");
        exit(EXIT_FAILURE);
    }    
return scannedt;
} 

int readboardsize() {
    int nvr,scannedn;
    printf("Enter n :");
    nvr = scanf("%d",&scannedn);
    if (scannedn>25 || scannedn<3) {
        printf("Incorrect input: n must be 3..25\n");
        exit(EXIT_FAILURE);
    }
return scannedn;
}
void readboard(int board[MAX][MAX], int n) {
    int i,j,nvr;

    printf("Enter %d by %d forrest:\n",n,n);
        for(i = 0; i < MAX; i++){
            for(j=0; j < MAX; j++){
                nvr = scanf("%d",&board[i][j]);      
            }
        }
}              
void printboard(int board[MAX][MAX]) {
    int i,j;
    printf("Here is the board:\n\n");
        for(i = 0; i < MAX; i++){
            for(j=0; j < MAX; j++){
                if (board[i][j]==0 ) {
                    printf(". ");
                }else if (board[i][j]==1){
                    printf("^ ");
                }else if (board[i][j]==2){
                    printf("* ");
                } 
            }      
        printf("\n");
        }
}

Когда я компилирую его, он успешно завершается, но после ввода массива я получаю эту ошибку:

*** stack smashing detected ***: ./ass2 terminated
======= Backtrace: =========
/lib/libc.so.6(__fortify_fail+0x50)[0x3e3990]
/lib/libc.so.6(+0xe593a)[0x3e393a]
./ass2[0x8048768]
/lib/libc.so.6(__libc_start_main+0xe7)[0x314ce7]
./ass2[0x8048421]
======= Memory map: ========
00110000-0012a000 r-xp 00000000 08:01 129968     /lib/libgcc_s.so.1
0012a000-0012b000 r--p 00019000 08:01 129968     /lib/libgcc_s.so.1
0012b000-0012c000 rw-p 0001a000 08:01 129968     /lib/libgcc_s.so.1
0025e000-0025f000 r-xp 00000000 00:00 0          [vdso]
002fe000-00455000 r-xp 00000000 08:01 134635     /lib/libc-2.12.1.so
00455000-00456000 ---p 00157000 08:01 134635     /lib/libc-2.12.1.so
00456000-00458000 r--p 00157000 08:01 134635     /lib/libc-2.12.1.so
00458000-00459000 rw-p 00159000 08:01 134635     /lib/libc-2.12.1.so
00459000-0045c000 rw-p 00000000 00:00 0 
00c1f000-00c3b000 r-xp 00000000 08:01 130134     /lib/ld-2.12.1.so
00c3b000-00c3c000 r--p 0001b000 08:01 130134     /lib/ld-2.12.1.so
00c3c000-00c3d000 rw-p 0001c000 08:01 130134     /lib/ld-2.12.1.so
08048000-08049000 r-xp 00000000 08:01 427835     /home/stu/Work/comp1911/ass2/ass2
08049000-0804a000 r--p 00000000 08:01 427835     /home/stu/Work/comp1911/ass2/ass2
0804a000-0804b000 rw-p 00001000 08:01 427835     /home/stu/Work/comp1911/ass2/ass2
09c12000-09c33000 rw-p 00000000 00:00 0          [heap]
b7830000-b7831000 rw-p 00000000 00:00 0 
b783e000-b7842000 rw-p 00000000 00:00 0 
bfe46000-bfe67000 rw-p 00000000 00:00 0          [stack]
Aborted

Может кто-нибудь дать мнерука с тем, что происходит?

С уважением

Деннис

1 Ответ

1 голос
/ 29 апреля 2011

Вы #define MAX n, а затем int n; чуть ниже этого.Таким образом, n будет инициализирован нулем, поскольку у него есть область файла (кто-то исправит меня, если я ошибаюсь, я проверил несколько примеров, но это не гарантия, и у меня нет копии стандартного удобного инструмента),Тогда у вас есть это в основном:

int board[MAX][MAX];

А потом чуть позже вы наконец присваиваете значение n и затем переходите к его использованию.Но ваш board был создан с использованием начального значения n.В результате все предполагают, что board больше, чем есть на самом деле, и именно так вы разбили свой стек.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...