顯然這個“11/22 Substring”是以那個“/”為中心對稱的。鑑於一個這樣的字串只能有一個“/”,而題目又要求最長,所以確定了“/”就能確定一個滿足要求的子串。
那思路就很簡單了,只有兩步:
-
找到所有的“/”
-
兩邊同時尋找相應的子串。
別的,除了判斷一下越界之外,就不用管了。
ACCode:
/*Code by Leo2011*/
#include <bits/stdc++.h>
#define INF 0x3f3f3f3f
#define EPS 1e-8
#define FOR(i, l, r) for (int(i) = (l); (i) <= (r); ++(i))
#define log printf
#define IOS \
ios::sync_with_stdio(false); \
cin.tie(nullptr); \
cout.tie(nullptr);
using namespace std;
typedef __int128 i128;
typedef long long ll;
typedef pair<int, int> PII;
int n, ans;
string s;
template <typename T>
inline T read() {
T sum = 0, fl = 1;
char ch = getchar();
for (; !isdigit(ch); ch = getchar())
if (ch == '-') fl = -1;
for (; isdigit(ch); ch = getchar()) sum = sum * 10 + ch - '0';
return sum * fl;
}
template <typename T>
inline void write(T x) {
if (x < 0) {
putchar('-'), write<T>(-x);
return;
}
static T sta[35];
int top = 0;
do { sta[top++] = x % 10, x /= 10; } while (x);
while (top) putchar(sta[--top] + 48);
}
int main() {
IOS;
cin >> n >> s;
for (int i = 0; i < n; ++i) {
if (s[i] == '/') {
int l = i - 1, r = i + 1, len = 1;
while (l >= 0 && r < n)
if (s[l] == '1' && s[r] == '2') --l, ++r, len += 2; // 左右同時尋找,所以是 +2
else break; // 不滿足了及時break
ans = max(ans, len);
}
}
write<int>(ans);
return 0;
}
AC 記錄~
理解萬歲!