結果
問題 | No.709 優勝可能性 |
ユーザー |
|
提出日時 | 2018-08-29 17:52:00 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 143 ms / 3,500 ms |
コード長 | 896 bytes |
コンパイル時間 | 701 ms |
コンパイル使用メモリ | 75,584 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-09-13 19:29:55 |
合計ジャッジ時間 | 3,199 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 22 |
ソースコード
#include<iostream> #include<stack> #include<vector> using namespace std; int main(){ int n, m, r; scanf("%d %d", &n, &m); int deg[100000] = {}; int paramax[10] = {}; vector<stack<int>> v(m); int ans = 0; for(int i = 0; i < n; i++){ for(int j = 0; j < m; j++){ scanf("%d", &r); if(r > paramax[j]){ while(!v[j].empty()){ int person = v[j].top(); v[j].pop(); deg[person]--; if(deg[person] == 0) ans--; } paramax[j] = r; deg[i]++; if(deg[i] == 1) ans++; v[j].push(i); }else if(r == paramax[j]){ v[j].push(i); deg[i]++; if(deg[i] == 1) ans++; } } printf("%d\n", ans); } return 0; }