結果
問題 | No.672 最長AB列 |
ユーザー |
![]() |
提出日時 | 2018-05-01 17:18:39 |
言語 | D (dmd 2.109.1) |
結果 |
AC
|
実行時間 | 33 ms / 2,000 ms |
コード長 | 826 bytes |
コンパイル時間 | 789 ms |
コンパイル使用メモリ | 103,988 KB |
実行使用メモリ | 19,780 KB |
最終ジャッジ日時 | 2024-06-13 00:57:56 |
合計ジャッジ時間 | 1,814 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 16 |
ソースコード
import std.algorithm; import std.array; import std.conv; import std.math; import std.range; import std.stdio; import std.string; import std.typecons; T read(T)() { return readln.chomp.to!T; } T[] reads(T)() { return readln.split.to!(T[]); } alias readint = read!int; alias readints = reads!int; int calc(string s) { int ans = 0; int[int] d = [0: -1]; int x = 0; for (int i = 0; i < s.length; i++) { switch (s[i]) { case 'A': x++; break; case 'B': x--; break; default: break; } if (x in d) { ans = max(ans, i - d[x]); } else { d[x] = i; } } return ans; } void main() { string s = readln.chomp; auto ans = calc(s); writeln(ans); }