2016-09-05 10 views
1

こんにちは私は動的迷路を構築しようとしています。私はサイズを取得し、それらから迷路を構築するために必要な文字を取得する部分になっています。 しかし、迷路を構築する関数は、実際には非対称であることを示しています。どうすれば修正できますか?関数が正しく機能していない

私のコード:

#include <stdio.h> 
    #include <stdlib.h> 

char **board; 
int size = 0; 

void print_Board(); 
void initialize_Board(); 

int main() 
{ 
    initialize_Board(); 
    print_Board(); 

return 0; 
} 

/*initialize the board*/ 
void initialize_Board() 
{ 
    int i, j;//indexs 
    char s; 
    scanf("%d", &size); 

board = (char**)malloc(sizeof(char*)* (size)); 
if (!board) { printf("ERROR - memroy allocation.\n"); exit(1); } 

for (i = 0; i < size; i++)//for loops to build the board for the game 
{ 
    board[i] = (char*)malloc(sizeof(char)*(size));        
    if (!board[i]) { printf("ERROR - memroy allocation, for loop\n"); 
     exit(1); 
    } 

    for (j = 0; j < size; j++) 
    { 
     scanf("%c", &s); 
     board[i][j] = s; 
    }//for col 

    printf("\n"); 

    }//for row 
} 

//print the board 
void print_Board() 
    { 
    int i, j; 

for (i = 0; i < size; i++) 
    { 
     for (j = 0; j < size; j++) 
     { 
     printf("%c ", board[i][j]); //print the value in the [i][j] place. 
     }//for col 

     printf("\n"); 

     }//for row 
} 
+3

サンプル出力を投稿してもよろしいですか? –

+0

[MCVE](http://stackoverflow.com/help/mcve)を投稿したことがありますか? – Mirakurun

+2

一つの推測では、各行の後にEnterを押すと、それは 'scanf'によって余分な文字として読み込まれます。 –

答えて

0

変更:

for (j = 0; j < size; j++) 
{ 
    scanf("%c", &s); 
    board[i][j] = s; 
}//for col 

へ:

for (j = 0; j < size; j++) { 
    scanf("%c ", &s); 
    board[i][j] = s; 
}//for col 
board[i][j] = '\n'; // Add new line to end of row making it a string. 

これは、各文字が読み取られ、戻りcharが破棄されることを保証します。

と変化:

int i, j; 
for (i = 0; i < size; i++) 
{ 
    for (j = 0; j < size; j++) 
    { 
     printf("%c ", board[i][j]); //print the value in the [i][j] place. 
    }//for col 

    printf("\n"); 

}//for row 

に:これは端で改行で各行を印刷

int i; 

for (i = 0; i < size; i++) { 
    printf("%s", board[i]); //print the values in the [i] row. 
} 

関連する問題