제출 #774785

#제출 시각아이디문제언어결과실행 시간메모리
774785vjudge1Stone Arranging 2 (JOI23_ho_t1)C++98
60 / 100
2067 ms3172 KiB
// #pragma GCC target("abm") // #pragma GCC optimize("03,unroll-loops") // #pragma GCC optimize("Ofast,unroll-loops") // #pragma GCC target("bmi,bmi2,lzcnt,popcnt") // #pragma GCC target("avx2") #include <bits/stdc++.h> #define FAST ios_base::sync_with_stdio(false); cin.tie(nullptr) #define put(a) cout << a << "\n" #define put_2(a, b) cout << a << " " << b << "\n" #define put_3(a, b, c) cout << a << " " << b << " " << c << "\n" #define put_4(a, b, c, x) cout << a << " " << b << " " << c << " " << x << "\n" #define put_5(a, b, c, x, y) cout << a << " " << b << " " << c << " " << x << " " << y << "\n"; #define put_6(a, b, c, x, y, z) cout << a << " " << b << " " << c << " " << x << " " << y << " " << z << "\n"; #define put_fix(a, n) cout << fixed << setprecision(n) << a << "\n" #define ll long long #define ldb long double #define db double #define sqr(x) (x*x) #define fto(i, a, b) for (int i = a; i <= b; ++i) #define fdto(i, b, a) for (int i = b; i >= a; --i) #define sz(a) (int) (a.size()) #define di deque <int> #define vi vector <int> #define vl vector <long long> #define pii pair <int, int> #define vii vector <int, int> #define vpii vector<pair<int, int>> #define pf push_front #define pb push_back #define ppf pop_front #define ppb pop_back #define eb emplace_back #define mp make_pair #define ff first #define ss second #define oo 1000000007 #define OO 1000000000000000007 #define eps 0.0000000001 #define mod #define maxN 200005 #define maxM 10000005 using namespace std; int n, a[maxN]; void sub_1() { for (int i = 2; i <= n; ++i) { int pos = 0; for (int j = i-1; j >= 1; --j) { if (a[j] == a[i]) { pos = j; break; } } if (pos) { for (int j = pos+1; j <= i-1; ++j) a[j] = a[i]; } } for (int i = 1; i <= n; ++i) cout << a[i] << "\n"; } void sub_2() { int mn_1 = oo, mn_2 = oo; int mx_1 = 0, mx_2 = 0; for (int i = 1; i <= n; ++i) { if (a[i] == 1) { mn_1 = min(mn_1, i); mx_1 = max(mx_1, i); } else { mn_2 = min(mn_2, i); mx_2 = max(mx_2, i); } } if (mn_1 < mn_2) { for (int i = 1; i <= n; ++i) { if (i <= mx_1) cout << "1\n"; else cout << a[i] << "\n"; } } else { for (int i = 1; i <= n; ++i) { if (i <= mx_2) cout << "2\n"; else cout << a[i] << "\n"; } } } int st_val[maxN]; void sub_3() { int pos = 1; while (1) { if (pos > n) break; bool found = false; for (int i = n; i >= pos+1; --i) { if (a[i] == a[pos]) { st_val[pos] = a[pos]; pos = i+1; found = true; } } if (!found) { st_val[pos] = a[pos]; ++pos; } } bool ok = false; int val = 0; for (int i = 1; i <= n; ++i) { if (st_val[i]) { ok = true; val = st_val[i]; } if (!ok) cout << a[i] << "\n"; else cout << val << "\n"; } } int main () { // #ifndef ONLINE_JUDGE // freopen("test.inp", "r", stdin); // freopen("test.out", "w", stdout); // #endif // ONLINE_JUDGE FAST; cin >> n; bool ok_o = false; for (int i = 1; i <= n; ++i) { cin >> a[i]; if (a[i] != 1 && a[2] != 2) ok_o = true; } // sub_3(); if (n <= 10000) sub_1(); else if (!ok_o) sub_2(); else sub_3(); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...