Submission #465018

#TimeUsernameProblemLanguageResultExecution timeMemory
465018TeaTimeMoney (IZhO17_money)C++17
25 / 100
1 ms332 KiB
//#pragma GCC optimize("O3") //#pragma GCC target("avx2") #include <iostream> #include <vector> #include <string> #include <algorithm> #include <map> #include <set> #include <queue> #include <unordered_map> using namespace std; #define fastInp cin.tie(0); cout.tie(0); ios_base::sync_with_stdio(0); typedef long long ll; typedef long double ld; #define int ll const ll SZ = 1e6 + 10, INF = 1e9; ll n, m, q; vector<ll> vec; signed main() { fastInp; cin >> n; vec.resize(n); ll ans = 0; for (auto& c : vec) cin >> c; multiset<ll> er; map<ll, ll> cnt_all; for (int i = 0; i < n; i++) { er.insert(vec[i]); cnt_all[vec[i]]++; } er.insert(INF); if (er.size() != n + 1) return 1; while (vec.size()) { ans++; ll cur = vec.back(); vector<ll> ltr; ltr.push_back(cur); vec.pop_back(); map<ll, ll> cnt; cnt[cur]++; while (vec.size() > 0) { if (vec.back() == cur) { ltr.push_back(vec.back()); cur = vec.back(); cnt[cur]++; vec.pop_back(); continue; } ll q = (*(er.upper_bound(vec.back()))); if (vec.size() > 0 && q == cur && (cnt.size() == 1 || cnt[cur] == cnt_all[cur])) { ltr.push_back(vec.back()); cur = vec.back(); cnt[cur]++; vec.pop_back(); } else { break; } } for (auto c : ltr) er.erase(er.find(c)); } if (er.size() != 1) return 1; cout << ans; return 0; }

Compilation message (stderr)

money.cpp: In function 'int main()':
money.cpp:41:19: warning: comparison of integer expressions of different signedness: 'std::multiset<long long int>::size_type' {aka 'long unsigned int'} and 'll' {aka 'long long int'} [-Wsign-compare]
   41 |     if (er.size() != n + 1) return 1;
      |         ~~~~~~~~~~^~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...