时间限制: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
输出例子1:
4 2 1 3
#include <bits/stdc++.h>
using namespace std;
int main() {
int n;
cin >> n;
long c[200005] = {0};
for (int i = 0; i < n; i++) {
cin >> c[i];
}
// odd
if (n & 1 == 1) {
for (int i = n-1; i >=0; i -= 2) {
if (i == n - 1)
cout << c[i];
else
cout << " " << c[i];
}
for (int i = 1; i < n; i += 2) {
cout << " " << c[i];
}
} else {
for (int i = n-1; i > 0; i -= 2) {
if (i == n-1)
cout << c[i];
else
cout << " " << c[i];
}
for (int i = 0; i < n; i += 2) {
cout << " " << c[i];
}
}
cout << endl;
return 0;
}