Submission #11619824
Source Code Expand
#include <iostream> #include <vector> #include <map> #include <set> #include <string> #include <utility> #include <algorithm> #include <cstdio> #include <iomanip> #include <queue> #include <deque> #include <stack> #include <fstream> #include <cmath> #include <random> #include <complex> #include <functional> #define ll int64_t #define Rep(i, n) for (ll i = 0; i < n; i++) using namespace std; typedef vector<ll> vec; typedef vector<vec> mat; const ll inf = 1LL << 60; template<class T> inline void chmin(T& a, T b) { if (a > b) { a = b; } } template<class T> inline void chmax(T& a, T b) { if (a < b) { a = b; } } int main(){ cin.tie(0); ios::sync_with_stdio(false); ll N, M; cin >> N >> M; vec X(N); map<ll, ll> cnt; Rep (i, N) { cin >> X[i]; cnt[X[i]]++; } map<ll, ll> p, m; for (auto e : cnt) { ll n = e.first, c = e.second; m[n%M] += c; p[n%M] += c/2; } // for (auto e : m) { // cout << e.first << " " << e.second << "\n"; // } ll ans = m[0]/2; if (M%2 == 0) ans += m[M/2]/2; for (ll i = 1; i < (M+1)/2; i++) { ll tmp = min(m[i], m[M-i]); ans += tmp; m[i] -= tmp; m[M-i] -= tmp; if (m[M-i] == 0) { ans += min(p[i], m[i]/2); } else { ans += min(p[M-i], m[M-i]/2); } } cout << ans << endl; }
Submission Info
Submission Time | |
---|---|
Task | D - Pair Cards |
User | charhan |
Language | C++14 (GCC 5.4.1) |
Score | 700 |
Code Size | 1515 Byte |
Status | AC |
Exec Time | 207 ms |
Memory | 19840 KB |
Judge Result
Set Name | sample | all | ||||
---|---|---|---|---|---|---|
Score / Max Score | 0 / 0 | 700 / 700 | ||||
Status |
|
|
Set Name | Test Cases |
---|---|
sample | sample-01.txt, sample-02.txt |
all | sample-01.txt, sample-02.txt, 01-01.txt, 01-02.txt, 01-03.txt, 01-04.txt, 01-05.txt, 01-06.txt, 01-07.txt, 01-08.txt, 01-09.txt, 01-10.txt, 01-11.txt, 01-12.txt, 01-13.txt, 01-14.txt, 01-15.txt, 01-16.txt, 01-17.txt, 01-18.txt, 01-19.txt, 01-20.txt, 01-21.txt, 01-22.txt, 01-23.txt, 01-24.txt, 01-25.txt, 01-26.txt, 01-27.txt, 01-28.txt, 01-29.txt, 01-30.txt, sample-01.txt, sample-02.txt |
Case Name | Status | Exec Time | Memory |
---|---|---|---|
01-01.txt | AC | 1 ms | 256 KB |
01-02.txt | AC | 39 ms | 4992 KB |
01-03.txt | AC | 39 ms | 4992 KB |
01-04.txt | AC | 43 ms | 4992 KB |
01-05.txt | AC | 39 ms | 4992 KB |
01-06.txt | AC | 46 ms | 4992 KB |
01-07.txt | AC | 45 ms | 4992 KB |
01-08.txt | AC | 46 ms | 5120 KB |
01-09.txt | AC | 48 ms | 5248 KB |
01-10.txt | AC | 90 ms | 9728 KB |
01-11.txt | AC | 161 ms | 15616 KB |
01-12.txt | AC | 9 ms | 1024 KB |
01-13.txt | AC | 35 ms | 5120 KB |
01-14.txt | AC | 48 ms | 7296 KB |
01-15.txt | AC | 47 ms | 7296 KB |
01-16.txt | AC | 50 ms | 7296 KB |
01-17.txt | AC | 56 ms | 7296 KB |
01-18.txt | AC | 59 ms | 7680 KB |
01-19.txt | AC | 74 ms | 8832 KB |
01-20.txt | AC | 207 ms | 19840 KB |
01-21.txt | AC | 18 ms | 1280 KB |
01-22.txt | AC | 18 ms | 1280 KB |
01-23.txt | AC | 18 ms | 1280 KB |
01-24.txt | AC | 19 ms | 1408 KB |
01-25.txt | AC | 31 ms | 4096 KB |
01-26.txt | AC | 64 ms | 10624 KB |
01-27.txt | AC | 138 ms | 13184 KB |
01-28.txt | AC | 47 ms | 9856 KB |
01-29.txt | AC | 15 ms | 3968 KB |
01-30.txt | AC | 59 ms | 9600 KB |
sample-01.txt | AC | 1 ms | 256 KB |
sample-02.txt | AC | 1 ms | 256 KB |