Codeforces Round 913 (Div. 3)B(预处理)

Codeforces Round 913 (Div. 3)B

预处理:

如果说一个数据是静态的,那可用预处理来减少运行时间。
在这里,我们对字符串的大小写字母做一个预处理,提前用数组记录下他们的位置,然后再根据题目要求对对应位置做标记删除就好,这种方法可以将复杂度从o(n^2)降低至o(n);

const:

用const 将一个变量量转化成具体数据,方便修改

#include <iostream>
#include <cstring>
#include <algorithm>

using namespace std;

const int N = 1e6 + 10;

int a[N];
int b[N];
int c[N];

int main() {
	int t;
	cin >> t;
	for (int j = 1; j <= t; j++) {
		string n;
		cin >> n;
		int b1 = 0;
		int c1 = 0;
		memset(a, 0, sizeof(a));
		for (int i = 0; i < n.length(); i++) {

			if (n[i] == 'B') {
				a[i] = -1;
				if (c1 >= 1) {
					a[c[c1--]] = -1;
				}

			} else if (n[i] == 'b') {
				a[i] = -1;
				if (b1 >= 1) {
					a[b[b1--]] = -1;
				}
			} else if (n[i] >= 'a' && n[i] <= 'z' ) {
				b[++b1] = i;
			} else  {
				c[++c1] = i;
			}
		}


		for (int i = 0; i < n.length(); i++) {
			if (a[i] != -1) {
				cout << n[i];
			}
		}
		cout << endl;
	}

	return 0;
}
posted @   拍手称快  阅读(62)  评论(1编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 2 本地部署DeepSeek模型构建本地知识库+联网搜索详细步骤
点击右上角即可分享
微信分享提示