首页 > 试题广场 >

操作序列

[编程题]操作序列
  • 热度指数:39 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 32M,其他语言64M
  • 算法知识视频讲解
小易有一个长度为n的整数序列,a_1,...,a_n。然后考虑在一个空序列b上进行n次以下操作:
1、将a_i放入b序列的末尾
2、逆置b序列
小易需要你计算输出操作n次之后的b序列。

输入描述:
输入包括两行,第一行包括一个整数n(2 ≤ n ≤ 2*10^5),即序列的长度。
第二行包括n个整数a_i(1 ≤ a_i ≤ 10^9),即序列a中的每个整数,以空格分割。


输出描述:
在一行中输出操作n次之后的b序列,以空格分割,行末无空格。
示例1

输入

4
1 2 3 4

输出

4 2 1 3
def operate(li):
    odd_loc = [li[i] for i in range(len(li)) if i & 1 == 0]
    even_loc = [li[i] for i in range(len(li)) if i & 1]
    if len(li) & 1 == 0:
        even_loc.reverse()
        print(' '.join(even_loc + odd_loc))
    else:
        odd_loc.reverse()
        print(' '.join(odd_loc + even_loc))


if __name__ == '__main__':
    n = int(input())
    li = input().split()
    operate(li)
发表于 2019-08-03 11:02:32 回复(0)