結果
問題 |
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 増加させます。 * 記録を更新します。 * また、最高スコアタイのときには、後半の処理だけを行います。 */