結果
問題 | No.709 優勝可能性 |
ユーザー |
![]() |
提出日時 | 2020-04-03 14:09:08 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 113 ms / 3,500 ms |
コード長 | 1,708 bytes |
コンパイル時間 | 2,053 ms |
コンパイル使用メモリ | 197,120 KB |
最終ジャッジ日時 | 2025-01-09 12:39:53 |
ジャッジサーバーID (参考情報) |
judge5 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 22 |
ソースコード
#include<bits/stdc++.h>using lint=long long;using real=long double;int main(){std::cin.tie(nullptr);std::ios_base::sync_with_stdio(false);std::cout.setf(std::ios_base::fixed);std::cout.precision(15);lint n,m;std::cin>>n>>m;std::vector<std::vector<lint>>legends(m);std::vector<lint>record(m),titles(n);lint ans=0;for(lint i=0;i<n;i++){for(lint j=0;j<m;j++){lint x;std::cin>>x;x--;if(record.at(j)<x){for(lint k:legends.at(j)){if(--titles.at(k)==0)ans--;}legends.at(j).clear();}if(record.at(j)<=x){record.at(j)=x;legends.at(j).push_back(i);if(++titles.at(i)==1)ans++;}}std::cout<<ans<<'\n';}}/** 次のものを管理します。* legends: vec<vec<lint>> = 各競技での記録保持者リスト* record: vec<lint> = 各競技での記録* titles: vec<lint> = 各人のタイトル数* ans: lint = 答え** 人が増えて、競技を進めていきます。* 最高スコアを更新したとき今までの記録保持者に関して、* 記録保持者リストから削除します。* タイトル数を 1 減少させます。* これで 0 になったら、答えを 1 減少させます。* さらに、* 新しい人を記録保持者に加えます。* タイトル数を 1 増加させます。* これで 1 になったら、答えを 1 増加させます。* 記録を更新します。* また、最高スコアタイのときには、後半の処理だけを行います。*/