pat 1012 數字分類 (20)

1012. 數字分類 (20)

時間限制
100 ms
內存限制
65536 kB
代碼長度限制
8000 B
判題程序
Standard
作者
CHEN, Yue

給定一系列正整數,請按要求對數字進行分類,並輸出以下5個數字:

A1 = 能被5整除的數字中所有偶數的和; A2 = 將被5除後餘1的數字按給出順序進行交錯求和,即計算n1-n2+n3-n4...; A3 = 被5除後餘2的數字的個數; A4 = 被5除後餘3的數字的平均數,精確到小數點後1位; A5 = 被5除後餘4的數字中最大數字。

輸入格式:

每個輸入包含1個測試用例。每個測試用例先給出一個不超過1000的正整數N,隨後給出N個不超過1000的待分類的正整數。數字間以空格分隔。

輸出格式:

對給定的N個正整數,按題目要求計算A1~A5並在一行中順序輸出。數字間以空格分隔,但行末不得有多餘空格。

若其中某一類數字不存在,則在相應位置輸出“N”。

輸入樣例1:
13 1 2 3 4 5 6 7 8 9 10 20 16 18
輸出樣例1:
30 11 2 9.7 9
輸入樣例2:
8 1 2 4 5 6 7 9 16
輸出樣例2:
N 11 2 N 9
i = map(int, raw_input().split())
sum1 ,sum2= 0, 0
k = -1
l,m = [],[]

flag1, flag2, flag3, flag4, flag5 = 0, 0, 0, 0, 0
for j in range(1,len(i)):
    if i[j] % 5 == 0 and i[j] % 2 == 0:
        sum1 = sum1 + i[j]
        flag1 = 1
    if i[j] % 5 == 1:
        k = k * -1
        sum2 = k*i[j] + sum2
        flag2 = 1
    if i[j] % 5 == 2:
        flag3 = flag3 + 1
    if i[j] % 5 == 3:
        l.append(i[j])
        flag4 = 1
    if i[j] % 5 == 4:
        m.append(i[j])
        flag5 = 1
if flag1:
    print sum1,
else:
    print "N",
if flag2:
    print sum2,
else:
    print "N",
if flag3:
    print flag3,
else:
    print "N",
if flag4:
    print "%.1f" % (float(sum(l)) / len(l)),
else:
    print "N",
if flag5:
    print max(m),
else:
    print "N",




發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章