Mofixen 2022-10-03 11:18 采纳率: 63.6%
浏览 15
已结题

二叉树建立为什么要清缓冲区

void foundtree(BiTree *root)
 {
     char x;
    fflush(stdin);
     scanf("%c",&x);

if(x=='#')
{
    *root=NULL;
}
else
{*root=(BiTree)malloc(sizeof(BiTreeNode));
(*root)->data=x;
foundtree(&(*root)->lchild);
foundtree(&(*root)->rchild);

}

}

为什么一定要加缓冲区



```

  • 写回答

2条回答 默认 最新

  • _GX_ 2022-10-03 11:58
    关注

    你不能对输入流调用fflush()函数,否则的话,你的程序的行为是未定义的。
    https://en.cppreference.com/w/c/io/fflush

    For input streams (and for update streams on which the last operation was input), the behavior is undefined.

    其实如果你是想忽略空白符,只要在%c前加个空格就行了。

    scanf(" %c",&x); // %c前添加一个空格,用来忽略任意个空白符(包括空格、制表符和回车)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 10月10日
  • 已采纳回答 10月3日
  • 创建了问题 10月3日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部