1

我的作业输入有问题。在标准输入上,我会得到一个特别格式化的输入。

在第一行中,将有 2 个整数,它们确定矩阵的大小(行和列)。之后的所有行代表矩阵的行。

我本质上想做一些类似 getline() 的事情,但我不想使用 getline()。事实上我不能,它在作业中被禁止。因此,我必须按 int 扫描 int(或者我猜是按 char 扫描)。这里的问题是我需要它是防弹的(几乎)。至少是防伪的。

我在想象一个大的 while 循环,它一直持续到 EOF 并在另一个循环中(也许?),它总是读取一行,将它保存到我分配的矩阵并继续到下一个。我知道我应该检查'\n',但我今天有点缺乏思考解决方案的能力。

这是我正在使用的:我的矩阵是一个结构。

struct Matrix{
    int nrows;
    int ncols;
    int** matrix;
};

然后我有多个功能。

为特定大小的矩阵动态分配空间的函数:

struct Matrix init_matrix(int r, int c)
{
    struct Matrix mat;
    mat.nrows = r;
    mat.ncols = c;
    mat.matrix = calloc(r, sizeof(int *));
    for(int i = 0; i < r; ++i)
    {
        *(mat.matrix+i) = calloc(c, sizeof(int));
    }

    return mat;
}

释放先前分配的空间的函数:

void free_matrix(struct Matrix mat)
{   
    int top = mat.nrows;
    for(int i = 0; i < top; ++i)
    {
        free(mat.matrix[i]);
    }
    free(mat.matrix);
}

这两个功能工作得很好。

现在我正在尝试创建一个函数 create_matrix(void) (至少我认为它不应该接受任何参数),它将读取我应该接收的输入,例如:

3 3
1 2 3
4 5 6
7 8 9

当函数读取输入时,它可以判断输入是否不正确或格式不正确,并以相应的退出值(如 100 fe)退出程序如果输入正确且格式正确,则调用 init_matrix() 然后将输入保存到矩阵。

为了您更深入的了解:我应该收到的整个输入是:矩阵 A(如上,第一行的大小,之后的行中的值)一个操作(+,-,*)矩阵 B

然后执行操作(A*B、A+B 等)。我正在尝试将大多数东西变成函数,所以 main 会很简单,fe

int main(int argc, char *argv[])
{
    struct Matrix mat1 = create_matrix();
    char operation = get_operation();
    struct Matrix mat2 = create_matrix();
    struct Matrix result = compute(mat1,mat2, operation);
    return 0;
}

如果你明白我的话,那些话里的东西。问题是我想让程序足够复杂,以便以后可以编辑它以处理比两个更大的矩阵序列(最多 100 个)。现在我可以用一种肮脏的方式来做,通过一次操作让它适用于两个矩阵,但这不是我真正想要的。

4

1 回答 1

1

好吧,这就是我解决它的方法。有用。它不是接近完美的地方,但它可以工作,上传系统接受它并给它全额积分,所以我很满意。

struct Matrix read_matrix(FILE *fp)
{
    struct Matrix mat;
    //FIRST LINE
    int ch;
    int i = 0;
    int n = 20;
    char* line = calloc(n,sizeof(char));
    while((ch = fgetc(fp)) != EOF && ch != '\n')
    {
        *(line + i++) = ch;
    }
    *(line + n-1) = '\0';
    int r,c;
    int k = sscanf(line,"%d %d", &r, &c);
    if(k != 2)
    {
        fprintf(stderr, "Error: Chybny vstup!\n");
        exit(100);
    } 
    free(line);
    //MATRIX
    line = calloc(c, sizeof(int));
    mat = init_matrix(r, c);
    i = 0;
    r = 0;
    while(r < mat.nrows && (ch = fgetc(fp)))
    {
        if(ch == '\n' || ch == EOF)
        {
            *(line + i) = '\0';
            int offset;
            char *data = line;
            for(int j = 0; j < mat.ncols; ++j)
            {
                int d = sscanf(data, " %d%n", &mat.matrix[r][j], &offset);
                if(d != 1){
                    fprintf(stderr, "Error: Chybny vstup!\n");
                    exit(100);
                }
                data += offset;
            }
            i = 0;
            ++r;
            if(ch == EOF){ 
                break;
            }
        } else
        {
            *(line + i++) = ch;
        }
    }
    free(line);
    return mat;
}
于 2017-11-25T21:07:00.993 回答