用c语言写本关任务:给出一个包含 n个整数的数列,问整数 a在数列中出现的次数,以及第一次出现的位置(位置从1开始编号)。 编程要求 输入:第一行输入整数 n。 第二行输入n个非负整数,为给定的数列。第三行输入整数a,为待查找的数。 输出:第一行输出整数a在数列中出现的次数。第二行 如果a在数列中出现了,则输出它第一次出现的位置,否则输出-1。
时间: 2024-02-11 07:10:03 浏览: 83
好的,以下是 C 语言的实现:
```c
#include <stdio.h>
int main() {
int n, a, count = 0, first_pos = -1;
scanf("%d", &n);
int nums[n];
for (int i = 0; i < n; i++) {
scanf("%d", &nums[i]);
}
scanf("%d", &a);
for (int i = 0; i < n; i++) {
if (nums[i] == a) {
count++;
if (first_pos == -1) {
first_pos = i + 1;
}
}
}
printf("%d\n", count);
printf("%d\n", first_pos);
return 0;
}
```
首先读取输入的 n 和数列中的 n 个非负整数,存储在一个数组中。然后再读取待查找的整数 a。接着遍历整个数组,统计整数 a 在数列中出现的次数,如果出现了,则记录整数 a 第一次出现的位置。最后输出整数 a 在数列中出现的次数以及第一次出现的位置。
需要注意的是,位置从 1 开始编号,所以在记录整数 a 第一次出现的位置时,需要将 i 加上 1。
如果您还不熟悉 C 语言的数组和循环等基本语法,建议先学习一下再进行编写。
阅读全文