【刷题】(AtCoder Beginner Contest 328) C、D 补题

前言

第一次打 a了两道 C、D都是TLE 看了其他人的题解之后 有一些想法 所以发一篇博客

C

题干

题目链接

我的思路及做题过程

我的思路是 输入left、right 再在这个区间内计算字母相同的对数

代码是:

cpp 复制代码
#include<iostream>
#include<cmath>
#include<algorithm>

using namespace std;

int main()
{
	int n, q, le, ri, _max = 0;
	string str;
	cin >> n >> q >> str;
	for (int i = 0; i < q; i++) {
		cin >> le >> ri;
		int num = 0;
		for (int j = le - 1; j < ri - 1; j++) {
			if (str[j] == str[j + 1]) {
				num++;
			}
		}
		cout << num << endl;
	}
	return 0;
}

tle了

优化

其实 在每一个小的区间里 对数是不变的

所以我们可以先遍历字符串找到每个小的区间内的对数

再根据输入的left和right输出相应区间内的对数

遍历

遍历的过程是下面这样

cpp 复制代码
for (int i = 1; i <= n; i++)
{
	if (str[i] == str[i - 1])
	{
		t++;
		num[i] = t;
	}
	else
	{
		num[i] = t;
	}
}
输出
cpp 复制代码
		cout << num[right - 1] - num[left - 1] << endl;

思考

写题要有自己的思考 不要题目说什么 就写什么

不然简单题也会吃亏

D

题干

题目链接

我的思路及做题过程

使用find函数和erase函数

find函数查找"ABC" erase函数删除"ABC"

但是TLE了

我在想是不是数据量大的时候 库函数太慢了

就只用循环和判断语句来写了

cpp 复制代码
#include<iostream>

using namespace std;

char a[200100];
string s;
int main() {
	cin >> s;
	int left = 0;
	int right = 0;
	while (left < s.size()) {
		right++;
		a[right] = s[left];
		//赋值给另一个数组
		if (right >= 3) {
			if (a[right] == 'C' && a[right - 1] == 'B' && a[right - 2] == 'A') {
			//满足条件 就减少输出的范围 即right
				right -= 3;
			}
		}
		left++;
	}
	for (int k = 1; k <= right; k++)
		cout << a[k];
	return 0;
}

总结

虽然库函数很好用 但遇到大的数据量的时候 还是要注意一些 很容易TLE

太痛苦了

结尾

AB没什么可说的 CD都是TLE E看了一眼 看到了图 不打算做了

第一次打atcoder 感觉还是不太好

菜就多练 以前是以前 现在是现在

我们下篇文章见

相关推荐
王老师青少年编程1 分钟前
csp信奥赛C++高频考点专项训练之字符串 --【字符串排序】:字符排序
c++·字符串·csp·高频考点·信奥赛·字符串排序·字符排序
杜子不疼.9 分钟前
【 C++ AI 大模型接入 SDK】 - 日志模块
开发语言·javascript·c++
3Tony22 分钟前
解决VScode报错:preLaunchTask“C/C++: gcc.exe 生成活动文件“已终止,退出代码为 -1.
c++·ide·vscode
knight_9___42 分钟前
大模型project面试4
人工智能·python·深度学习·算法·面试·agent
l1t1 小时前
DeepSeek总结的欢迎来到 ORDER BY 丛林
数据库·算法
谙弆悕博士1 小时前
【附C源码】二叉搜索树的C语言实现
c语言·开发语言·数据结构·算法·二叉树·项目实战·数据结构与算法
C+++Python1 小时前
C++ 泛型编程 极简示例代码
开发语言·c++
Rust研习社1 小时前
Ubuntu 全面拥抱 Rust 后,我意识到 Rust 社区要变了
linux·服务器·开发语言·后端·ubuntu·rust
宵时待雨1 小时前
回溯算法专题2:二叉树中的深搜
开发语言·数据结构·c++·笔记·算法·深度优先
jiayong231 小时前
第 43 课:任务详情抽屉里的批量处理闭环与删除联动
java·开发语言·前端