結果
問題 | No.273 回文分解 |
ユーザー | wahr69 |
提出日時 | 2015-08-28 23:02:43 |
言語 | C++11 (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 1,127 bytes |
コンパイル時間 | 653 ms |
コンパイル使用メモリ | 85,516 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-06-25 13:25:01 |
合計ジャッジ時間 | 1,633 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 32 |
ソースコード
#include <iostream> #include <array> #include <vector> #include <list> #include <stack> #include <queue> #include <set> #include <map> #include <unordered_set> #include <unordered_map> #include <algorithm> #include <string> #include <sstream> #include <memory> #include <cassert> #include <functional> using namespace std; const int MOD = 1000000007; typedef unsigned long long ull; int main() { string s; cin >> s; if (s.size() == 2) { cout << 1 << endl; return 0; } for (int len = s.size() - 1; len >= 2; --len) { // 文字数 for (int j = 0; j < s.size() - len + 1; ++j) { // 開始位置 bool isKaibun = false; int count = 1; for (int k = j; true; ++k) { // 今の位置 int back = j + len - count; if (k == back) { isKaibun = true; break; } if (k + 1 == back) { if (s[k] == s[back]) { isKaibun = true; } else { isKaibun = false; } break; } if (s[k] != s[back]) { isKaibun = false; break; } ++count; } if (isKaibun) { cout << len << endl; return 0; } } } cout << 1 << endl; return 0; }