整数查找:
问题描述
给出一个包含n个整数的数列,问整数a在数列中的第一次出现是第几个。
输入格式
第一行包含一个整数n。
第二行包含n个非负整数,为给定的数列,数列中的每个数都不大于10000。
第三行包含一个整数a,为待查找的数。
输出格式
如果a在数列中出现了,输出它第一次出现的位置(位置从1开始编号),否则输出-1。
样例输入
6
1 9 4 8 3 9
9
样例输出
2
数据规模与约定
1 <= n <= 1000。
代码如下:
#include <stdio.h>
#include <stdlib.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
int main(int argc, char *argv[]) {
int n, i, s=-1,t=0;
int a[1000];
scanf("%d", &n);
for(i = 0; i < n; i++){
scanf("%d", &a[i]);
if(a[i] >= 0 && a[i] <= 10000)
continue;
else
scanf("%d",&a[i]);
}
scanf("%d", &t);
for(i = 0; i < n; i++){
if(a[i] == t){
s = i+1; //需要思考怎样输出-1,这是一个问题
break;
}
}
printf("%d",s);
return 0;
}
这个题目我学到了,就是输出 -1 的方法,很简单,但是先前我没想到。