結果
| 問題 | No.1479 Matrix Eraser |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2021-04-16 20:29:20 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.89.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,776 bytes |
| 記録 | |
| コンパイル時間 | 3,865 ms |
| コンパイル使用メモリ | 232,676 KB |
| 最終ジャッジ日時 | 2025-01-20 18:49:15 |
|
ジャッジサーバーID (参考情報) |
judge3 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 26 WA * 13 |
ソースコード
#pragma GCC optimize("Ofast")
#include <bits/stdc++.h>
using namespace std;
typedef long long int ll;
typedef unsigned long long ull;
mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count());
ll myRand(ll B) {
return (ull)rng() % B;
}
int main(){
cin.tie(nullptr);
ios::sync_with_stdio(false);
int n,m; cin >> n >> m;
vector<vector<int>> a(n,vector<int>(m));
map<int,vector<pair<int,int>>> mp;
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
cin >> a[i][j];
mp[a[i][j]].push_back({i,j});
}
}
int res=0;
vector<int> v(n),vv(m);
vector<int> c(n),d(m);
for(auto p:mp){
if(p.first==0)continue;
fill(v.begin(), v.end(),0);
fill(vv.begin(), vv.end(),0);
fill(c.begin(), c.end(),0);
fill(d.begin(), d.end(),0);
for(auto pp:p.second){
v[pp.first]++;
vv[pp.second]++;
}
priority_queue<pair<int,pair<int,int>>> pq;
for(auto pp:p.second){
pq.push(make_pair(v[pp.first]+vv[pp.second]-1,pp));
}
while(pq.size()){
auto pp=pq.top(); pq.pop();
if(c[pp.second.first] or d[pp.second.second])continue;
if(pp.first!=v[pp.second.first]+vv[pp.second.second]-1){
pq.push(make_pair(v[pp.second.first]+vv[pp.second.second]-1,pp.second));
continue;
}
if(v[pp.second.first]>=vv[pp.second.second]){
c[pp.second.first]=1;
res++;
vv[pp.second.second]--;
}
else{
d[pp.second.second]=1;
res++;
v[pp.second.first]--;
}
}
}
cout << res << endl;
}