Submission #7364020


Source Code Expand

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include <stack>
#include <queue>
#include <cmath>
#include <tuple>
#include <cstdio>
#include <bitset>
#include <sstream>
#include <iterator>
#include <numeric>
#include <map>
#include <cstring>
#include <set>
#include <functional>
#include <iomanip>

using namespace std;

#define DEBUG_ //!!提出時にコメントアウト!!
#ifdef DEBUG_
	#define dump(x)  cerr << #x << " = " << (x) << endl;
#else
	#define dump(x)  ;
#endif

#define EPS (1e-10)
#define equals(a,b) (fabs((a)-(b)) < EPS)
#define FOR(i,a,b) for(int i=(a);i<(b);++i)
#define REP(i,n)  FOR(i,0,n)
#define SZ(x) ((int)(x).size())
#define pb push_back
#define eb emplace_back

//#define int long long

typedef long long LL;
typedef vector<int> VI;
typedef vector<LL> VL;
typedef vector<VI> VVI;
typedef vector<string> VS;
typedef pair<int, int> PII;
typedef pair<LL, LL> PLL;

template <typename T>
std::string printVector(const std::vector<T> &data)
{
    std::stringstream ss;
    std::ostream_iterator<T> out_it(ss, ", ");
    ss << "[";
    std::copy(data.begin(), data.end() - 1, out_it);
    ss << data.back() << "]";
    return ss.str();
}

const int MOD = 1e9+7;
const LL LINF = 1001002003004005006ll;
const int INF = 1001001001;

signed main(int argc, char const *argv[])
{
    cin.tie(0);
    ios::sync_with_stdio(false);
    int N,M; cin >> N >> M;
    VI X(N);
    map<int,int> mp;
    int cnt[112345] = {};
    VI db[112345];
    int add[112345] = {};
    REP(i,N) {
        cin >> X[i];
        mp[X[i]]++;
        cnt[X[i]%M]++;
    }
    for(auto p : mp){
        if(p.second >= 2){
            db[p.first%M].eb(p.second);
        }
    }

    for(auto p : mp){
        add[p.first%M] += p.second / 2;
    }

    int ans = 0;
    for(int i = 0; i <= M-i; i++){
        if(i == 0 || i == M-i){
            ans += cnt[i] / 2;
        }else{
            int s = cnt[i];
            int t = cnt[M-i];
            if(s==t) ans += s;
            else if(s > t){
                ans += t;
                ans += min(add[s],(s-t)/2);
            }else{
                ans += s;
                ans += min(add[t],(t-s)/2);
            }
        }
    }
    cout << ans << endl;

}

Submission Info

Submission Time
Task D - Pair Cards
User Bloody_Yulii
Language C++14 (GCC 5.4.1)
Score 0
Code Size 2340 Byte
Status WA
Exec Time 50 ms
Memory 8832 KB

Judge Result

Set Name sample all
Score / Max Score 0 / 0 0 / 700
Status
AC × 2
AC × 19
WA × 15
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 3 ms 3712 KB
01-02.txt AC 40 ms 7424 KB
01-03.txt AC 41 ms 7296 KB
01-04.txt WA 40 ms 7296 KB
01-05.txt WA 40 ms 7296 KB
01-06.txt WA 40 ms 7296 KB
01-07.txt WA 40 ms 7296 KB
01-08.txt AC 41 ms 7296 KB
01-09.txt WA 42 ms 7296 KB
01-10.txt WA 43 ms 7808 KB
01-11.txt WA 44 ms 7936 KB
01-12.txt WA 11 ms 4224 KB
01-13.txt WA 11 ms 4224 KB
01-14.txt AC 48 ms 8832 KB
01-15.txt AC 49 ms 8832 KB
01-16.txt AC 49 ms 8832 KB
01-17.txt AC 49 ms 8832 KB
01-18.txt AC 49 ms 8832 KB
01-19.txt AC 49 ms 8832 KB
01-20.txt AC 50 ms 8832 KB
01-21.txt AC 19 ms 4352 KB
01-22.txt WA 20 ms 4352 KB
01-23.txt WA 19 ms 4352 KB
01-24.txt WA 20 ms 4352 KB
01-25.txt WA 21 ms 4480 KB
01-26.txt WA 21 ms 4480 KB
01-27.txt AC 23 ms 6272 KB
01-28.txt WA 4 ms 3968 KB
01-29.txt AC 3 ms 3840 KB
01-30.txt AC 3 ms 3712 KB
sample-01.txt AC 2 ms 3712 KB
sample-02.txt AC 3 ms 3712 KB