結果

問題 No.267 トランプソート
ユーザー peroonperoon
提出日時 2019-06-05 22:04:42
言語 C++14
(gcc 13.2.0 + boost 1.83.0)
結果
AC  
実行時間 2 ms / 1,000 ms
コード長 2,001 bytes
コンパイル時間 2,059 ms
コンパイル使用メモリ 177,336 KB
実行使用メモリ 4,348 KB
最終ジャッジ日時 2023-10-22 08:21:16
合計ジャッジ時間 3,121 ms
ジャッジサーバーID
(参考情報)
judge9 / judge12
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
4,348 KB
testcase_01 AC 2 ms
4,348 KB
testcase_02 AC 2 ms
4,348 KB
testcase_03 AC 2 ms
4,348 KB
testcase_04 AC 2 ms
4,348 KB
testcase_05 AC 2 ms
4,348 KB
testcase_06 AC 2 ms
4,348 KB
testcase_07 AC 2 ms
4,348 KB
testcase_08 AC 2 ms
4,348 KB
testcase_09 AC 2 ms
4,348 KB
testcase_10 AC 2 ms
4,348 KB
testcase_11 AC 2 ms
4,348 KB
testcase_12 AC 2 ms
4,348 KB
testcase_13 AC 2 ms
4,348 KB
testcase_14 AC 2 ms
4,348 KB
testcase_15 AC 2 ms
4,348 KB
testcase_16 AC 2 ms
4,348 KB
testcase_17 AC 2 ms
4,348 KB
testcase_18 AC 2 ms
4,348 KB
testcase_19 AC 2 ms
4,348 KB
testcase_20 AC 2 ms
4,348 KB
testcase_21 AC 2 ms
4,348 KB
testcase_22 AC 2 ms
4,348 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<bits/stdc++.h>
using namespace std;
using ll = long long;

template<class T>bool chmax(T &a, const T &b) { if (a<b) { a=b; return 1; } return 0; }
template<class T>bool chmin(T &a, const T &b) { if (b<a) { a=b; return 1; } return 0; }

#define FOR(i,a,b) for(ll i=(a);i<(b);++i)
#define ALL(v) (v).begin(), (v).end()
#define p(s) cout<<(s)<<endl
#define p2(s, t) cout << (s) << " " << (t) << endl
#define br() p("")
#define pn(s) cout << (#s) << " " << (s) << endl

int ctoi(char c) {
	if (c >= '0' && c <= '9') {
		return c - '0';
	}
	return 0;
}

string pair_to_str(pair<ll, ll> p){
    stringstream ss;
    ll mark = p.first;
    if(mark==0){
        ss << 'D';
    }else if(mark==1){
        ss << 'C';
    }else if(mark==2){
        ss << 'H';
    }else{
        ss << 'S';
    }

    ll num = p.second;
    if(num==1){
        ss << 'A';
    }else if(num<10){
        ss << num;
    }else if(num==10){
        ss << 'T';
    }else if(num==11){
        ss << 'J';
    }else if(num==12){
        ss << 'Q';
    }else{
        ss << 'K';
    }

    return ss.str();
}

int main(){
    cin.tie(0);
    ios::sync_with_stdio(false);

    // input
    ll N;
    cin >> N;

    vector<pair<ll, ll> > A;
    FOR(i, 0, N){
        string s; cin >> s;

        char mark = s[0];
        ll m;
        if(mark=='D'){
            m = 0;
        }else if(mark=='C'){
            m = 1;
        }else if(mark=='H'){
            m = 2;
        }else{
            m = 3;
        }

        ll num;
        char c = s[1];
        if(c=='T'){
            num = 10;
        }else if(c=='J'){
            num = 11;
        }else if(c=='Q'){
            num = 12;
        }else if(c=='K'){
            num = 13;
        }else if(c=='A'){
            num = 1;
        }else{
            num = ctoi(c);
        }

        A.push_back(make_pair(m, num));
    }
    sort(ALL(A));

    FOR(i, 0, A.size()){
        if(i) cout << ' ';
        cout << pair_to_str(A[i]);
    }
    cout << endl;
    
    return 0;
}
0