/ SeriousOJ /

Record Detail

Accepted


  
# Status Time Cost Memory Cost
#1 Accepted 1ms 532.0 KiB
#2 Accepted 31ms 832.0 KiB
#3 Accepted 31ms 836.0 KiB
#4 Accepted 32ms 832.0 KiB
#5 Accepted 30ms 836.0 KiB
#6 Accepted 35ms 788.0 KiB
#7 Accepted 30ms 844.0 KiB
#8 Accepted 30ms 832.0 KiB
#9 Accepted 57ms 776.0 KiB
#10 Accepted 30ms 788.0 KiB
#11 Accepted 31ms 788.0 KiB
#12 Accepted 31ms 820.0 KiB
#13 Accepted 31ms 872.0 KiB
#14 Accepted 57ms 852.0 KiB
#15 Accepted 30ms 792.0 KiB
#16 Accepted 31ms 788.0 KiB
#17 Accepted 29ms 788.0 KiB
#18 Accepted 31ms 624.0 KiB
#19 Accepted 30ms 788.0 KiB
#20 Accepted 31ms 804.0 KiB
#21 Accepted 35ms 788.0 KiB
#22 Accepted 39ms 3.004 MiB
#23 Accepted 29ms 2.789 MiB
#24 Accepted 32ms 3.086 MiB
#25 Accepted 53ms 2.52 MiB
#26 Accepted 35ms 3.266 MiB
#27 Accepted 31ms 3.129 MiB
#28 Accepted 27ms 2.324 MiB
#29 Accepted 38ms 3.098 MiB
#30 Accepted 28ms 3.062 MiB
#31 Accepted 32ms 3.078 MiB
#32 Accepted 30ms 888.0 KiB
#33 Accepted 31ms 924.0 KiB
#34 Accepted 30ms 928.0 KiB
#35 Accepted 30ms 888.0 KiB
#36 Accepted 30ms 924.0 KiB
#37 Accepted 1ms 532.0 KiB
#38 Accepted 2ms 532.0 KiB
#39 Accepted 2ms 532.0 KiB
#40 Accepted 3ms 532.0 KiB
#41 Accepted 5ms 532.0 KiB
#42 Accepted 58ms 3.77 MiB
#43 Accepted 32ms 3.816 MiB
#44 Accepted 32ms 3.77 MiB
#45 Accepted 24ms 3.77 MiB
#46 Accepted 25ms 3.77 MiB
#47 Accepted 25ms 3.926 MiB
#48 Accepted 50ms 3.77 MiB
#49 Accepted 25ms 3.77 MiB
#50 Accepted 26ms 3.77 MiB

Code

#include <bits/stdc++.h>
#define pb push_back
#define pf push_front
#define pi 2*acos(0.0)
#define f first
#define s second
#define inf INT_MAX
#define MXN 500001
#define endl "\n"
#define eps 1e-6
#define mod 1000000007
#define all(x) x.begin(), x.end()
#define rev(x) x.rbegin(), x.rend()
#define spc(x) cout << fixed << setprecision(x)
#define fastio {ios_base::sync_with_stdio(false); cin.tie(NULL);}
#define test ll t; cin >> t; while (t--)

typedef long long ll;
using namespace std;

void solve()
{
    ll n, m;
    cin >> n >> m;

    vector<string> v(n);
    for(int i = 0; i < n; i++) {
        cin >> v[i];
    }

    if(n == 1) {
        cout << m << endl;
        return;
    }

    ll ans = 0;
    vector<vector<ll>> pref(n, vector<ll>(m, 0));
    vector<vector<ll>> suff(n, vector<ll>(m, 0));
    
    for(int i = 0; i < m; i++) {
        map<char, ll> mp1, mpp1;
        ll mxx = 0, mxx1 = 0;
        
        for(int j = 0; j < n; j++) {
            mp1[v[j][i]]++;
            mxx = max(mxx, mp1[v[j][i]]);
            pref[j][i] = mxx;
        }

        for(int j = n - 1; j >= 0; j--) {
            mpp1[v[j][i]]++;
            mxx1 = max(mxx1, mpp1[v[j][i]]);
            suff[j][i] = mxx1;
        }
    }
    
     
    for(int i=0;i<n;i++){
      ll tot=0;

         for(int j=0;j<m;j++){
          
          if(i<n-1){
          tot+=pref[i][j]+suff[i+1][j];
          }
          else{
               tot+=pref[i][j];
          }
      }
      ans=max(ans,tot);
    }
    
    cout << ans << endl;
}

int32_t main()
{
    fastio
    int t = 1;
    cin >> t;
    while (t--) {
        solve();
    }
    return 0;
}

Information

Submit By
Type
Submission
Problem
P1164 Simple character matching game
Language
C++17 (G++ 13.2.0)
Submit At
2025-02-17 19:41:25
Judged At
2025-02-17 19:41:25
Judged By
Score
100
Total Time
58ms
Peak Memory
3.926 MiB