結果
| 問題 |
No.709 優勝可能性
|
| コンテスト | |
| ユーザー |
ngtkana
|
| 提出日時 | 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 増加させます。
* 記録を更新します。
* また、最高スコアタイのときには、後半の処理だけを行います。
*/
ngtkana