输入一行 k 个用空格分隔开的整数,依次为 n1, n2 … nk。请将所有下标不能被
3 但可以被 2 整除的数在这些数字原有的位置上进行升序排列,此外,将余下下标能被 3 整除的数在这些数字原有的位置上进行降序排列。
输出包括一行,与输入相对应的若干个整数,为排序后的结果,整数之间用空格分隔。
t = raw_input().split(' ')
n = len(t)q=[]
p=[]
for k in range(1,n+1):
if k%3 != 0 and k%2 == 0:
q.append(t[k-1])
elif k%3 == 0:
p.append(t[k-1])
for x1 in range(0,len(q)):
q[x1]=int(q[x1])
for y1 in range(0,len(p)):
p[y1]=int(p[y1])
q1 = sorted(q, reverse=False)
p1 = sorted(p, reverse=True)
for x in range(0,len(p1)):
t[(x+1)*3-1] = p1[x]
num = 0
for y in range(1,n+1):
if y%3 != 0 and y%2 == 0:
t[y-1] = q1[num]
num += 1
for o in range(0,n):
t[o] = int(t[o])
print t[o],
1.没有用到所谓function,纯粹面向过程编程。
2.没有及时将字符转化为int,导致排序时按照字符排,后面纠正。
3.按一行输出 #print XXX,# 在要输出的后加上",",可以按行输出。
问题:
在什么地方可以简单的把输入的字符转化为数字?