Codeforces 不接受我的输出,即使它看起来完全一样?

Codeforces not accepting my output even though it looks exactly the same?

我正在尝试完成一个关于 codeforces 的低级问题,但即使我的解决方案通过了测试,它仍然注册为错误。它一直说 "wrong output format Unexpected end of file - int32 expected"。这是什么意思?可以在 https://codeforces.com/contest/1154/problem/A

找到问题
#a+b = w
#a+c = x
#b+c = y
#a+b+c = z
def restore_numbers(w,x,y,z):
    biggest = max(w,y,z,x)
    if biggest - w > 0:
        num = biggest-w
    else:
        num = biggest
    if biggest - x > 0:
        num1 = biggest-x
    else:
        num1 = biggest
    if biggest -y > 0:
        num2 = biggest-y
    else:
        num2 = biggest
    if biggest - z > 0:
        num3 = biggest-z
    else:
        num3 = biggest-z
    arr = [num,num1,num2,num3]
    arr.sort()
    arr = arr[0:3]
    s = [str(i) for i in arr]
    res = (" ".join(s))
    return res 
print(restore_numbers(3,6,5,4))

应该发生的是我解决了所有的测试,但这并没有发生。

您的代码将在不同的输入下 运行 多次,因此您的代码必须适应才能读取各种输入。为了实现这一点,您必须从输入的来源读取:stdin(标准输入)

在 python 中,您可以使用 input()stdin 中读取,然后将这些值传递给您的 restore_numbers(w,x,y,z)

但是,这些数字都在输入的一行中(例如 3 6 5 4),因此您可以创建一个包含 intmap 并从一行中获取输入, 并使用 split() 使用默认分隔符 (space) 分隔数字。然后你把它变成一个 list 并单独访问每个数字以传递到 restore_numbers(w,x,y,z) 函数。

一个解决方案是:

#a+b = w
#a+c = x
#b+c = y
#a+b+c = z
def restore_numbers(w,x,y,z):
  biggest = max(w,y,z,x)
  if biggest - w > 0:
      num = biggest-w
  else:
      num = biggest
  if biggest - x > 0:
      num1 = biggest-x
  else:
      num1 = biggest
  if biggest -y > 0:
      num2 = biggest-y
  else:
      num2 = biggest
  if biggest - z > 0:
      num3 = biggest-z
  else:
      num3 = biggest-z
  arr = [num,num1,num2,num3]
  arr.sort()
  arr = arr[0:3]
  s = [str(i) for i in arr]
  res = (" ".join(s))
  return res
nums = list(map(int, input().split()))
print(restore_numbers(nums[0],nums[1],nums[2],nums[3]))

现在代码可以在各种输入中 运行 多次。