結果
問題 | No.2178 Payable Magic Items |
ユーザー |
![]() |
提出日時 | 2023-01-06 23:37:44 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,089 bytes |
コンパイル時間 | 2,136 ms |
コンパイル使用メモリ | 212,344 KB |
最終ジャッジ日時 | 2025-02-10 00:30:46 |
ジャッジサーバーID (参考情報) |
judge4 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 12 WA * 11 |
ソースコード
#include<bits/stdc++.h>using namespace std;#pragma GCC target("avx2")#pragma GCC optimize("O3")#pragma GCC optimize("unroll-loops")#define rep(i,n) for (int i=0;i<(long long)(n);i++)#define all(v) v.begin(),v.end()using ll=long long;using pll=pair<ll,ll>;using tll=tuple<ll,ll,ll>;const ll INF=(1ll<<60);template<class T> void chmin(T &a,T b){if(a>b){a=b;}}template<class T> void chmax(T &a,T b){if(a<b){a=b;}}int main(){ll n,k;cin >> n >> k;vector<vector<char>> s(n,vector<char>(k));rep(i,n){rep(j,k){cin >> s[i][j];}}if(n<=1e4){set<ll> ans;rep(i,n){for(ll j=i+1;j<n;j++){if(ans.count(i)) break;if(ans.count(j)) continue;bool a=true,b=true;rep(l,k){if(s[j][l]<s[i][l]){a=false;}if(s[i][l]<s[j][l]){b=false;}}if(a) ans.insert(i);if(b) ans.insert(j);}}cout << ans.size() << endl;return 0;}vector<ll> v;rep(i,(1<<k)){vector<ll> p;rep(j,k){if(i&(1<<j)) p.push_back(j);}vector<ll> x(p.size());ll save=0;rep(j,n){if(j==0) continue;bool t=true;rep(l,p.size()){if(s[j][p[l]]<=s[save][p[l]]){t=false;break;}}if(t){save=j;}}v.push_back(save);}set<ll> ans;for(auto &i:v){rep(j,n){if(i==j) continue;bool t=true;rep(l,k){if(s[i][l]<s[j][l]){t=false;break;}}if(t) ans.insert(j);}}cout << ans.size() << endl;}