题解:AT_abc381_c [ABC381C] 11/22 Substring

Leo2011 魔怔哥

显然这个 “11/22 Substring” 是以那个 “/” 为中心对称的。鉴于一个这样的字符串只能有一个 “/”,而题目又要求最长,所以确定了 “/” 就能确定一个满足要求的子串

那思路就很简单了,只有两步:

  1. 找到所有的 “/”

  2. 两边同时寻找相应的子串。

别的,除了判断一下越界之外,就不用管了。


ACCode:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*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 记录~

理解万岁!

  • 标题: 题解:AT_abc381_c [ABC381C] 11/22 Substring
  • 作者: Leo2011
  • 创建于 : 2024-11-23 22:24:02
  • 更新于 : 2024-11-23 22:24:25
  • 链接: https://www.leo2011.eu.org/2024/11/23/ti-jie-at-abc381-c-abc381c-11-22-substring/
  • 版权声明: 本文章采用 CC BY-NC-SA 4.0 进行许可。
评论
目录
题解:AT_abc381_c [ABC381C] 11/22 Substring