资源限制
内存限制:256.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s
问题描述
给出一个包含n个整数的数列,问整数a在数列中的第一次出现是第几个。
输入格式
第一行包含一个整数n。
第二行包含n个非负整数,为给定的数列,数列中的每个数都不大于10000。
第三行包含一个整数a,为待查找的数。
输出格式
如果a在数列中出现了,输出它第一次出现的位置(位置从1开始编号),否则输出-1。
样例输入
6
1 9 4 8 3 9
9
样例输出
2
数据规模与约定
1 <= n <= 1000。
思路
1.注意列表读入语句不要写错:l = list(map(int,input().split()))
2.Python中for后接else的语法使用方法:
程序一、
for i in range(4):
print(i)
else:
print("666")
可知,运行结果如下图所示,可以发现语句顺序执行。
程序二、
for i in range(4):
print(i)
if i ==3:
break
else:
print("666")
其运行结果如下图,可以发现,语句执行至break
之后,并未执行后面的else
部分。
程序三、
for i in range(4):
print(i)
if i ==5:
break
else:
print("666")
其运行结果如下图,else
中的语句被正常执行。
通过对比,不难发现在for循环
正常结束后,else
中的语句会正常执行。而当for循环
被break
中断,则是不执行else
中的语句,此题主要用的就是这种思想。
代码
n = int(input())
l = list(map(int,input().split()))
m = int(input())
if n>=1 and n<=1000:
for i in range(n):
if l[i]==m:
print(i+1)
break
else:
print(-1)
运行截图