1 條題解
-
0
奇怪的写法,正常是全用
vector排序的,用了priority_queue和bitset#include <bits/stdc++.h> using namespace std; constexpr int N = 2e5 + 10; int main() { int n; cin >> n; priority_queue<int, vector<int>, greater<>> odd, even; bitset<N> isodd; for (int i = 0; i < n; ++i) { int m; cin >> m; if (m & 1) { isodd[i] = true; odd.push(m); } else { even.push(m); } } for (int i = 0; i < n; ++i) { if (isodd[i]) { cout << odd.top() << ' '; odd.pop(); } else { cout << even.top() << ' '; even.pop(); } } return 0; }
資訊
- ID
- 409
- 時間
- 2000ms
- 記憶體
- 512MiB
- 難度
- 10
- 标签
- (無)
- 遞交數
- 3
- 已通過
- 1
- 上傳者