yueyufeng 发表于 2023-11-19 10:58:48

找数组中 a[i - 1] < a[i] > a[i + 1] 的次数

isdkz 发表于 2023-11-19 10:58:54

你的代码有一个问题,你的循环条件应该是 while(scanf("%d",&n)!=EOF) ,而不是 while(scanf("%d",&n)!=EOF) 。这是因为你想要在输入结束前不断地读取输入。另外,你的代码中没有对 count 进行重置,这会导致计数错误。你需要在每次输入新的数组时将 count 重置为0。修改后的代码如下所示:

#include <stdio.h>

int main() {
    int n, i, count;
    int a;
   
    while (scanf("%d", &n) != EOF) {
      count = 0; // 重置count
      for (i = 0; i < n; i++) {
            scanf("%d", &a[ i]);
      }
      for (i = 1; i <= n - 2; i++) {
            if (a[ i] > a && a[ i] > a) {
                count++;
            }
      }
      printf("%d\n", count);
    }
    return 0;
}

Mike_python小 发表于 2023-11-19 10:59:43

看起来这段代码有一些问题。首先,你提到有输出错误,但是我没有看到具体的错误信息。不过根据你的描述,这段代码可能存在一些逻辑上的问题。

首先,你使用了while(scanf("%d",&n)!=EOF)来读取输入,这意味着你希望能够多次读取输入并进行处理。然而,在每次循环中,你只输出了一次结果,这可能不符合你的预期。

其次,对于每次输入的数组,你只计算了一次满足条件a < a > a的次数,并输出了结果。然后程序继续等待下一次输入。这可能并不是你想要的行为。

如果你希望多次输入数组,并对每个数组分别计算满足条件的次数并输出,那么你可能需要在循环中对count进行清零操作,或者将count放在循环内部,以确保每个数组的计数结果是独立的。

另外,你也没有给出具体的输出错误信息,如果你能提供更多的细节,我可以更准确地帮助你找出问题所在。
页: [1]
查看完整版本: 找数组中 a[i - 1] < a[i] > a[i + 1] 的次数