Codechef - python代码中的NZEC错误

时间:2015-08-22 09:34:28

标签: python

代码在我的机器上运行正常,但是当我在codechef上编译它时会产生NZEC(运行时错误)。

问题的链接:https://www.codechef.com/problems/PPTEST

关于我的解决方案:我根据时间和点值计算了每个测试用例的百分位数。然后,我根据百分位数对每个测试用例中的条目进行了排序。

import sys
def check(x):
    if not(x in range(1,100)):
        sys.exit(1)
T = input()
check(T)

N_W = []
C_P_T = {}
tp = []
tt = []

for i in range(0,T):
    tp.append(0)
    tt.append(0)
    N_W.append(map(int, raw_input().split())) 

    check(N_W[i][0])
    check(N_W[i][1]) 

    C_P_T[i] = []
    for j in range(0,N_W[i][0]):
        C_P_T[i].append(map(int, raw_input().split()))

        check(C_P_T[i][j][0])
        check(C_P_T[i][j][1])
        check(C_P_T[i][j][2])

        C_P_T[i][j].append(N_W[i][1]-C_P_T[i][j][2])
        C_P_T[i][j].append(C_P_T[i][j][1]*C_P_T[i][j][0])
        C_P_T[i][j].pop(0)
        C_P_T[i][j].pop(0)
        C_P_T[i][j].pop(0)
        tp[i]+= C_P_T[i][j][1]
        tt[i]+=C_P_T[i][j][0]


for i in range(0,T):
    C_P_T[i].sort(key = lambda x : x[0] , reverse = True)
    item_time = C_P_T[i][0][0]
    percentile_time = (C_P_T[i][0][0]/float(tt[i]))*((len(C_P_T[i])-1)/float(len(C_P_T[i])))

    for j in range(0,N_W[i][0]):
        if C_P_T[i][j][0] == item_time:
            C_P_T[i][j].append(percentile_time)
        else:
            item_time = C_P_T[i][j][0]
            percentile_time = (C_P_T[i][j][0]/float(tt[i]))*((len(C_P_T[i])-j-1)/float(len(C_P_T[i])))
            C_P_T[i][j].append(percentile_time)

for i in range(0,T):
    C_P_T[i].sort(key = lambda x : x[1] , reverse = True)
    item_points = C_P_T[i][0][1]
    percentile_points = (C_P_T[i][0][1]/float(tp[i]))*((len(C_P_T[i])-1)/float(len(C_P_T[i])))

    for j in range(0,N_W[i][0]):
        if C_P_T[i][j][1] == item_points:
            C_P_T[i][j].append(percentile_points)
        else:
            item_points = C_P_T[i][j][1]
            percentile_points = ((C_P_T[i][j][1])/float(tp[i]))*((len(C_P_T[i])-j-1)/float(len(C_P_T[i])))
            C_P_T[i][j].append(percentile_points)

    C_P_T[i][j].append(C_P_T[i][j][2]+C_P_T[i][j][3])
    C_P_T[i][j].append(N_W[i][1]-C_P_T[i][j][0])
    C_P_T[i][j].pop(2)
    C_P_T[i][j].pop(2)

    C_P_T[i].sort(key = lambda x : x[2],reverse = True)

for i in range(0,T):
    points = 0
    for j in range(0,N_W[i][0]):
        if N_W[i][1]-C_P_T[i][j][3] >= 0:
            points+=C_P_T[i][j][1]
            N_W[i][1]-=C_P_T[i][j][3]
    print points

1 个答案:

答案 0 :(得分:0)

NZEC表示"非零退出代码",因此可能发生在sys.exit(1)函数的check()中。您从input()收到的信息不是整数,也不在正确的范围内。

更新:我注意到您使用range(1, 100)进行有效性测试。

但是,codechef的问题描述表明1 ≤ T ≤ 100。这相当于range(1, 101)

因此,codechef可能会将您的代码传递给完全有效的100,并且您的代码会拒绝它,可能会出现您所看到的确切错误。