代码似乎在正确的轨道上,但是它会跳出一行并忽略第一个元素[0,0]将一切完全推回一个元素。
#include <stdio.h>
#include <stdlib.h>
int main()
{
char **nums;
int i,j,k, num_cases;
int rows, cols;
printf("Enter the number of grids.\n");
scanf("%d", &num_cases);
for(k=0;k<num_cases;k++){
printf("Test Case #%d\n", k+1);
printf("Enter the # of rows & columns separated by a space.\n");
scanf("%d%d", &rows, &cols);
nums = (char**)malloc(rows*sizeof(char*));
for(i=0; i<rows; i++){
nums[i] = (char*)malloc(cols*sizeof(char));
}
printf("Enter your %dx%d grid of letters.\n", rows, cols);
for(i=0; i<rows; i++){
for(j=0; j<cols; j++){
scanf("%c", &nums[i][j]);
}
}
}
for(i=0; i<rows; i++){
for(j=0; j<cols; j++){
printf("[%d][%d] = %c\n", i, j, nums[i][j]);
}
}
for(i=0; i<rows; i++){
free(nums[i]);
}
free(nums);
return 0;
}
答案 0 :(得分:1)
这一行
scanf("%d%d", &rows, &cols);
在输入缓冲区中留下newline
,因为"%d"
格式消耗前导空格而不是尾随空格。所以当这一行被执行时
scanf("%c", &nums[i][j]);
它会读取剩下的newline
。您可以通过在"%c"
前面添加一个空格来处理此问题
scanf(" %c", &nums[i][j]);
将消耗您想要读取的字符之前的任何前导空格。