結果
| 問題 | No.505 カードの数式2 |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-10-10 19:50:58 |
| 言語 | C++17 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 704 bytes |
| 記録 | |
| コンパイル時間 | 1,228 ms |
| コンパイル使用メモリ | 213,756 KB |
| 実行使用メモリ | 6,400 KB |
| 最終ジャッジ日時 | 2026-06-28 00:13:40 |
| 合計ジャッジ時間 | 2,365 ms |
|
ジャッジサーバーID (参考情報) |
judge1_1 / judge3_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 29 |
ソースコード
#include <bits/stdc++.h>
#define rep(i,n) for(int i = 0; i < (n); i++)
using namespace std;
typedef long long ll;
int main(){
cin.tie(0);
ios::sync_with_stdio(0);
int N; cin >> N;
vector<ll> a(N);
rep(i,N) cin >> a[i];
ll ma = a[0], mi = a[0];
rep(i,N) if(i) {
ll nt_ma = max({ma + a[i], ma - a[i], ma * a[i], mi + a[i], mi - a[i], mi * a[i]});
ll nt_mi = min({ma + a[i], ma - a[i], ma * a[i], mi + a[i], mi - a[i], mi * a[i]});
if(a[i] != 0) {
nt_ma = max({nt_ma, ma / a[i], mi / a[i]});
nt_mi = min({nt_mi, ma / a[i], mi / a[i]});
}
tie(ma, mi) = make_pair(nt_ma, nt_mi);
}
cout << ma << endl;
}