关于#链表#的问题,如何解决?


#include
#include
struct Node
{
    char x;
    struct Node *next;
};
void addL(struct Node **head)
{
    struct Node *node; 
    static struct Node *tail;
    node=(struct Node*)malloc(sizeof(struct Node));
    getInput(node); 
    if(*head!=NULL)
    {
        tail->next=node;
        node->next=NULL;
    }
    else
    {
    *head=node;
     node->next=NULL;
    }
    tail=node;
};
getInput(struct Node *node)
{
    scanf("%c",&node->x);
};
void printL(struct Node*head)
{
    struct Node *node;
    node=head;
    while(node!=NULL)
    {
        printf("%c",node->x);
        node=node->next;
    }
};
void releaseL(struct Node *head)
{
    struct Node *temp;
    while(head!=NULL)
    {
        temp=head->next;
        free(head);
        head=temp;
    }
};
int main(void) 
{
    struct Node *head=NULL;
    int i;
    for(i=0;i<6;i++)
        addL(&head);
        printL(head);
        releaseL(head);
        return 0;
}

程序要求是:输入字符a至f,按输入字符顺序建立一个字符结点(每个结点寸一个字符)的单向链表,输出该链表,并释放空间。
代码存在问题:在运行过程中,循环6次,只能输入3个字符;循环12次才能得到结果。
请问各位,是什么原因导致这一结果,那么该如何改正呢?
感谢各位!

原因:

  • 循环6次,每次输完一个字符,你就换行,实际上这个换行还在输入流里,下一次输入字符直接接收的就是换行,所以你 6次 实际上 只 输入了3个字符,再加上 3个换行

解决:

  • 可以在每次输入完,都用 getchar() 接收下换行符

如有帮助,欢迎点赞+采纳哈!