在数组中检查一个数字是否存在的程序

4
我写了下面这段C代码来检查用户输入的数组中是否存在一个数字。但奇怪的是,它跳过了第三个printf语句,直接获取输入并在获取该输入后打印Enter the number you wish to look for。这是什么原因?下面是代码和输入/输出框。

代码:

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

  void main() {
    int arr[30], size, i, num, flag=0;

    printf("Enter size of array. \n");
    scanf("%d",&size);

    printf("Enter %d array elements one by one. \n",size);
    for (i=0; i<size; i++) {
        scanf("%d \n",&arr[i]);
    }

    printf("Enter the number you wish to look for. \n");
    scanf("%d",&num);

    for(i=0;i<size;i++) {
        if (num == arr[i]) {
            flag++;
        }
    }

    if (flag>0) {
        printf("The number %d is present in the array.",num);
    } else {
        printf("The number %d is not present in the array.",num);
    }
 }

INPUT/OUTPUT:

Enter size of array.
5
Enter 5 array elements one by one.
1
2
3
4
5
5
Enter the number you wish to look for.
The number 5 is present in the array.

您可以看到,输入您想要查找的数字。应该在5之前显示,但事实并非如此。


解决方法

只需从scanf中删除\n即可解决问题。


你正在使用scanf()而没有进行检查。要更加谨慎小心。阅读规范并寻找你没有预料到的事情。如果发现了一些问题,请证明它们在你的情况下不会发生。 - Yunnosch
抱歉,我不理解你的评论。程序运行正常,唯一的问题是它先获取输入,然后再打印那一行。您能指出为什么会这样吗?再次道歉。 - Sagar Vrajalal
两个被点赞的回答都谈到了你使用scanf()的问题。问题在于你没有预料到的行为。我建议阅读规范并寻找你没有预料到的事情。对于未来的应用程序,你可能会发现这很有趣:http://sekrit.de/webdocs/c/beginners-guide-away-from-scanf.html - Yunnosch
2个回答

2
输入格式字符串中的空格"%d \n"告诉输入系统从输入中消耗所有连续的空格字符(在此处描述)。因此,当您输入最后一个数字5时,系统现在尝试消耗所有的空格字符。为了做到这一点,它会等待额外的输入,直到不是空格为止。因此,具有讽刺意味的是,为了消耗空格,系统必须读取非空格字符,即您输入的第二个数字5
要修复此行为,您可以告诉系统仅输入一个数字,而不是消耗空格:
    scanf("%d",&arr[i]);

然而,这将在缓冲区中留下空格,可能会干扰后续输入。要丢弃空格,您可以使用各种技术,例如在此处中描述的技术。
在我看来,最正确的技术(但可能是最神秘的技术)是...
    scanf("%d%*[^\n]%*c",&arr[i]);
  • %d - 读取数字
  • %*[^\n] - 读取一个以换行字节结尾的字符串;将其丢弃并不存储在任何地方
  • %*c - 读取一个字节(即换行符);将其丢弃并不存储在任何地方

顺便提一下,在您的格式字符串"%d \n"中,有两个空格:一个是普通空格,一个是行末空格。它们都告诉scanf消费输入中的所有空格。其效果与一个空格"%d "或一个行末"%d\n"相同,因此这种特定的格式字符串可能会让阅读您代码的人(包括您自己)感到非常困惑。


2
scanf中,空格字符已经表示任何空白符。所以在您的"%d \n"中,函数已经处理了最后一个数字后面的换行符,但是您又强制它等待另一个换行符。
这会导致程序等待另一行输入。在输入后,程序继续并要求输入要搜索的数字,此时输入已经完成。
只使用一个空格在scanf中,它已经可以处理换行符,理想情况下应该在数字本身之前,这样您就不需要额外的行来完成操作:
scanf(" %d", arr + i);

谢谢!你为我解决了疑惑。 - Sagar Vrajalal

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接