尝试解决问题,但Hackerrank的编译器在解析时继续抛出错误EOFError:不知道我错在哪里。
#!usr/bin/python
b=[]
b=raw_input().split()
c=[]
d=[]
a=raw_input()
c=a.split()
f=b[1]
l=int(b[1])
if(len(c)==int(b[0])):
for i in range(l,len(c)):
d.append(c[i])
#print c[i]
for i in range(int(f)):
d.append(c[i])
#print c[i]
for j in range(len(d)):
print d[j],
我也尝试过try来解决它,但后来没有输入。
try:
a=input()
c=a.split()
except(EOFError):
a=""
输入格式是开头的2个间隔整数,然后是数组
回溯错误是:
Traceback (most recent call last):
File "solution.py", line 4, in <module>
b=raw_input().split()
EOFError: EOF when reading a line
答案 0 :(得分:1)
有几种方法可以处理EOF错误。
1.抛出异常:
while True:
try:
value = raw_input()
do_stuff(value) # next line was found
except (EOFError):
break #end of file reached
2.检查输入内容:
while True:
value = raw_input()
if (value != ""):
do_stuff(value) # next line was found
else:
break
3。使用sys.stdin.readlines()
将它们转换为列表,然后使用for-each循环。更详细的解释是Why does standard input() cause an EOF error
import sys
# Read input and assemble Phone Book
n = int(input())
phoneBook = {}
for i in range(n):
contact = input().split(' ')
phoneBook[contact[0]] = contact[1]
# Process Queries
lines = sys.stdin.readlines() # convert lines to list
for i in lines:
name = i.strip()
if name in phoneBook:
print(name + '=' + str( phoneBook[name] ))
else:
print('Not found')
答案 1 :(得分:1)
我遇到了同样的问题。这是我注意到的。我还没有见过你的#34;主要&#34;功能,但Hackerrank已经为我们读取了所有数据。我们不需要阅读任何内容。例如,这是一个函数def doSomething(a, b):
a和b,无论是数组还是整数都将为我们读入。我们只需要专注于我们的主要代码而不必担心阅读。最后确保你的函数return()
,否则你会得到另一个错误。 Hackerrank也负责打印最终输出。他们的代码示例和常见问题解答有点误导。 根据我的测试,这是我的观察。您的测试可能会有所不同。
答案 2 :(得分:0)
我不知道,但提供自定义输入并编译它并让我进来!并通过所有案件,甚至没有改变任何事情。
答案 3 :(得分:0)
这是因为您的函数需要输入,但未提供。提供自定义输入并尝试对其进行编译。应该可以。
答案 4 :(得分:0)
在HackerRank的主要可见代码下方隐藏了一些代码。
您需要扩展该代码(观察出现错误的行号,并通过扩展检查该行)代码,并且这些代码有效,您需要将顶部可见的代码与隐藏的代码进行匹配。
我的情况如下:
regex_integer_in_range = r"___________" # Do not delete 'r'.
regex_alternating_repetitive_digit_pair = r"__________" # Do not delete 'r'.
我只是像下面那样填充上面的空白,并且使用给定的隐藏代码可以正常工作:
regex_integer_in_range = r"^[0-9][\d]{5}$" # Do not delete 'r'.
regex_alternating_repetitive_digit_pair = r"(\d)(?=\d\1)" # Do not delete 'r'.