我在接受 C 中的 N 字符串行时遇到 fscanf 和 fgets 的分段错误

I get segmentation error with fscanf and fgets in accepting N string lines in C

我有一个包含变量 x、y 和 z 的多项式结构

struct Node
{
    float coeff;
    int powX;
    int powY;
    int powZ;
    struct Node* next;
};

我想以 powX powY powZ coeff 的形式读取 n 多项式的用户输入,我有一个 for 循环,但它给我 分段错误 。可能是什么问题?

void readPolynomial(struct Node** poly)
{
    struct Node* temp = (struct Node*)malloc(sizeof(struct Node));
    *poly = temp;

    int terms;
    fscanf(stdin, "%d", &terms);
    getchar();

    char entry[200];
    char * splitter;
    for(int i = 0; i < terms; i++)
    {
        fgets(entry, 200, stdin);
        
        splitter = strtok(entry," ");
        temp->powX = atoi(splitter);
        splitter = strtok(NULL, " ");
        temp->powY = atoi(splitter);
        splitter = strtok(NULL, " ");
        temp->powZ = atoi(splitter);
        splitter = strtok(NULL, " ");
        temp->coeff = atof(splitter);
        temp->next = NULL;
        if(i != terms-1)
        {
            temp->next = (struct Node*)malloc(sizeof(struct Node));
            temp = temp->next;
            temp->next = NULL;
        }
    }
}

这是我的主要功能:

int main()
{
    struct Node* first = NULL;

    readPolynomial(&first);
    return 0;
}

对于多项式4x⁵y⁴z²5 4 2 4

示例输入:

3
5 4 2 4
1 6 0 -7
1 0 1 9

完整代码功能:获取两个多项式的和,按规范顺序打印

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

struct Node
{
    float coeff;
    int powX;
    int powY;
    int powZ;
    struct Node* next;
};


void readPolynomial(struct Node** poly)
{
    struct Node* temp = (struct Node*)malloc(sizeof(struct Node));
    *poly = temp;

    int terms;
    fscanf(stdin, "%d", &terms);
    getchar();

    char entry[200];
    char *splitter;
    for(int i = 0; i < terms; i++)
    {
        fgets(entry, 200, stdin);
        splitter = strtok(entry," ");
        temp->powX = atoi(splitter);
        splitter = strtok(NULL, " ");
        temp->powY = atoi(splitter);
        splitter = strtok(NULL, " ");
        temp->powZ = atoi(splitter);
        splitter = strtok(NULL, " ");
        temp->coeff = atof(splitter);
        temp->next = NULL;
        if(i != terms-1)
        {
            temp->next = (struct Node*)malloc(sizeof(struct Node));
            temp = temp->next;
            temp->next = NULL;
        }
    }
}

int degree(struct Node *term) {
    return (term->powX*pow(10, 2)) + (term->powY*pow(10, 1)) + (term->powZ*pow(10, 0));
}

int termCount(struct Node* poly)
{
    int count = 0;
    while(poly != NULL)
    {
        count++;
        poly = poly->next;
    }
    return count;
}

void displayPolynomial(struct Node* poly)
{
    int c = termCount(poly);
    struct Node *temp1, *t, *temp2;
    int tempX, tempY, tempZ, tempCoeff;
    for(int i = c-2; i>= 0; i--)
    {
        temp1 = poly;
        temp2 = temp1->next;
        for(int j = 0; j <= i; j++)
        {
            if(degree(temp1) < degree(temp2))
            {
                tempX = temp1->powX;
                tempY = temp1->powY;
                tempZ = temp1->powZ;
                tempCoeff = temp1->coeff;

                temp1->powX = temp2->powX;
                temp1->powY = temp2->powY;
                temp1->powZ = temp2->powZ;
                temp1->coeff = temp2->coeff;

                temp2->powX = tempX;
                temp2->powY = tempY;
                temp2->powZ = tempZ;
                temp2->coeff = tempCoeff;
            }
            temp1 = temp2;
            temp2 = temp2->next;
        }
    }
    t = poly;
    while(t != NULL)
    {
        printf("%d %d %d %.3f\n", t->powX, t->powY, t->powZ, t->coeff);
        t = t->next;
    }
}

void addPolynomials(struct Node** result, struct Node* first, struct Node* second)
{
    struct Node* temp = (struct Node*)malloc(sizeof(struct Node));
    temp->next = NULL;
    *result = temp;
    while(first && second)
    {
        if(((first->powX*pow(10, 2)) + (first->powY*pow(10, 1)) + (first->powZ*pow(10, 0))) < (((second->powX*pow(10, 2)) + (second->powY*pow(10, 1)) + (second->powZ*pow(10, 0)))))
        {
            temp->coeff = second->coeff;
            temp->powX = second->powX;
            temp->powY = second->powY;
            temp->powZ = second->powZ;
            second = second->next;

        }
        else if(((first->powX*pow(10, 2)) + (first->powY*pow(10, 1)) + (first->powZ*pow(10, 0))) > (((second->powX*pow(10, 2)) + (second->powY*pow(10, 1)) + (second->powZ*pow(10, 0)))))
        {
            temp->coeff = first->coeff;
            temp->powX = first->powX;
            temp->powY = first->powY;
            temp->powZ = first->powZ;
            first = first->next;
        }
        else
        {
            temp->coeff = first->coeff + second->coeff;
            temp->powX = first->powX;
            temp->powY = first->powY;
            temp->powZ = first->powZ;
            first = first->next;
            second = second->next;
        }
        if(first && second)
        {
            temp->next = (struct Node*)malloc(sizeof(struct Node));
            temp = temp->next;
            temp->next = NULL;
        }
    }
    while(first || second)
    {
        temp->next = (struct Node*)malloc(sizeof(struct Node));
        temp = temp->next;
        temp->next = NULL;

        if(second)
        {
            temp->coeff = second->coeff;
            temp->powX = second->powX;
            temp->powY = second->powY;
            temp->powZ = second->powZ;
            second = second->next;
        }

        else if(first)
        {
            temp->coeff = first->coeff;
            temp->powX = first->powX;
            temp->powY = first->powY;
            temp->powZ = first->powZ;
            first = first->next;
        }
    }
}

int main()
{
    struct Node* first = NULL;
    struct Node* second = NULL;
    struct Node* result = NULL;

    readPolynomial(&first);
    readPolynomial(&second);
    addPolynomials(&result, first, second);
    displayPolynomial(result);
    return 0;
}

示例输入:

3
1 6 0 -7
0 7 0 -6
7 0 0 1
5
1 0 1 9
0 7 0 -2
5 3 2 4
1 2 3 4
1 3 0 3

示例输出:

7 0 0 1.000
5 3 2 4.000
1 6 0 -7.000
1 3 0 3.000
1 2 3 4.000
1 0 1 9.000
0 7 0 -8.000

编译时出现完整警告(在 gcc 中为 -Wall -Wextra)。

在这种情况下,您会发现您没有包含 <string.h>,C 允许隐式声明 (int (*)()),但行为不是您想要的。

将以下内容添加到您的代码中,

#include <string.h>