首页 > 其他分享 >题解:AT_abc381_c [ABC381C] 11/22 Substring

题解:AT_abc381_c [ABC381C] 11/22 Substring

时间:2024-11-23 22:46:45浏览次数:10  
标签:11 ch 22 int 题解 sum ans top

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

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

  1. 找到所有的“/”

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

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


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 记录~

理解万岁!

标签:11,ch,22,int,题解,sum,ans,top
From: https://www.cnblogs.com/leo2011/p/18565179

相关文章

  • 【C++】C++11引入的新特性(1)
    生命有多长,不悲不喜。青春多荒凉,不骄不躁。假如生命止于明天,那么我们能必须珍惜今天。......
  • 1123模拟赛
    \(T1\),注意点与边不同阶时分着开,别开小了。\(T2\)当dp数组由于太大开不下时,可以用记忆化搜索代替。最长不公共子序列:首先可推出\(f[i][j]=min(f[i-1][j],f[i][j-1])(a[i]==b[j]),f[i-1][j-1]+1(a[i]!=b[j])\),由于一段连续的\(a[i]!=b[j]\)可以一下全消掉,所以可以看一个\(a[i]......
  • 高级java每日一道面试题-2024年11月22日-JVM篇-说说堆和栈的区别?
    如果有遗漏,评论区告诉我进行补充面试官:说说堆和栈的区别?我回答:在Java高级面试中,关于堆和栈的区别是一个常见的问题。堆和栈是JVM(Java虚拟机)内存模型中的两个重要部分,它们在程序执行过程中扮演着不同的角色。下面是对堆和栈的详细解释:堆(Heap)定义:堆是JVM中最......
  • 高级java每日一道面试题-2024年11月21日-数据结构篇-红黑树有哪几个特征?
    如果有遗漏,评论区告诉我进行补充面试官:红黑树有哪几个特征?我回答:红黑树(Red-BlackTree)是一种自平衡二叉查找树(Self-BalancingBinarySearchTree),它在插入和删除操作后能够自动保持树的高度平衡。红黑树在许多实际应用中都非常有用,例如在Java的TreeMap和TreeSe......
  • 2025--炼石计划-- 11 月 23 日 --NOIP 模拟赛 #23
    2025--炼石计划--11月23日--NOIP模拟赛#23\(T1\)A.排序\(100pts\)仅考虑临项比较时必要的一位的选择即可。点击查看代码lla[1000010],ans[35][2];llask(){ llx=0; for(lli=31;i>=0;i--) { if(ans[i][0]!=0&&ans[i][1]!=0) { return-1; } i......
  • 20241123-四元数高阶奇异值分解-(1)
    四元数高阶奇异值分解及其在彩色图像处理中的应用-(1)......
  • 20241123-四元数高阶奇异值分解-(4-5)
    四元数高阶奇异值分解及其在彩色图像处理中的应用-(4-5)......
  • [题解](更新中)[test06]2024/11/23 模拟赛 / 2023牛客OI赛前集训营-提高组(第三场) A~C
    原题页面:https://ac.nowcoder.com/acm/contest/65194Statements&Solution:https://www.luogu.com.cn/problem/U507978\(80+80+50+24=234\)。A贪心+双指针。根据贪心思想,大值选大、小值选小。我们按绝对值从大到小给\(a\)排序,再按从小到大给\(b\)排序,取双指针\(l=1,r=m\)......
  • COCI2021-2022#4 Šarenlist
    luogu。问题描述:有\(k\)种颜色对一棵树的所有边进行染色,给定\(m\)条限制,每条限制要求\(u,v\)路径上的所有边至少有两种颜色,问染色的方案总数。注意到数据范围:\(m\le15\),明显的一个经典容斥。如何求钦定一些路径颜色全部相同的方案数?对于要求颜色相同的边用并查集并起来,......
  • 题解 - Birds
    题目题目大意一条直线上有\(n\)棵树,第\(i\)棵树上有\(c_i\)​只鸟。在第\(i\)棵树下召唤一只鸟的魔力代价是\(cost_i\)​。每召唤一只鸟,魔力上限会增加\(B\)。每向前走一棵树,会增加\(X\)的魔力。一开始的魔力和魔力上限都是\(W\)。你只能向前移动。问最多能够召......