結果
| 問題 |
No.509 塗りつぶしツール
|
| コンテスト | |
| ユーザー |
@abcde
|
| 提出日時 | 2019-03-18 00:17:14 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 971 bytes |
| コンパイル時間 | 1,113 ms |
| コンパイル使用メモリ | 158,204 KB |
| 実行使用メモリ | 5,376 KB |
| 最終ジャッジ日時 | 2024-07-08 07:43:20 |
| 合計ジャッジ時間 | 2,025 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 27 |
ソースコード
// 解答不能.
// 題意解読不能 及び ロジック誤りのため, 再提出.
#include <bits/stdc++.h>
using namespace std;
int main() {
// 1. 入力情報取得.
string N;
cin >> N;
// 2. 0 ~ 9 の 塗りなおし.
// 1, 2, 3, 5, 7 … 3回, 0, 4, 6, 9 … 4回, 8 … 5回
int ans = 0;
int l = N.size();
// 2-1. 文字を青色に塗りつぶす.
// ans += l;
// 2-2. 背景を黒色に塗りつぶす.
// ans++;
for(int i = 0; i < l; i++){
if(N[i] == '0' || N[i] == '4' || N[i] == '6' || N[i] == '9') ans++;
if(N[i] == '8') ans += 2;
}
// 2-3. 文字を白色に塗りつぶす.
// ans += l;
// 3. 後処理.
// ex.
// 1234567890987654321 -> 50回?
// -> 正解者様の解答を実行すると, 43回なので, こっちが正解らしい.
ans = min(l * 2 + ans + 1, (ans + 1) * 2 + l);
cout << ans << endl;
return 0;
}
@abcde