解法:预处理 + 前后缀分解 / 二分查找

题目每次询问会给出一个区间,只需要找出这个区间内‘#’第一次出现的位置和最后一次出现的位置即可。

下面提供两种做法。

  • 前后缀分解 - 时间复杂度 O(N + q):
#include <iostream>
#include <algorithm>
#define endl '\n'

using namespace std;

const int N = 5e5 + 10;

int n, q;
string s;
int l, r;
int pre[N], suf[N];

int main() {
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	
	cin >> n >> q >> s;
	int p = -1;
	for(int i = 0; i < n; i++) {
		if(s[i] == '.') pre[i + 1] = p;
		else pre[i + 1] = i + 1, p = i + 1;
	}
	p = n + 1;
	for(int i = n - 1; i >= 0; i--) {
		if(s[i] == '.') suf[i + 1] = p;
		else suf[i + 1] = i + 1, p = i + 1;
	}
	
	while(q--) {
		cin >> l >> r;
		if(l > r) swap(l, r);
		cout << max(0, pre[r] - suf[l] + 1) << endl;
	}
	
	return 0;
}
  • 二分查找 - 时间复杂度 O(N + q * logN):
#include <iostream>
#include <algorithm>
#include <vector>
#define endl '\n'

using namespace std;

int n, q;
string s;

int main() {
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	
	cin >> n >> q >> s;
	vector<int> v;
	for(int i = 0; i < n; i++) {
		if(s[i] == '#') v.push_back(i + 1);
	}
	while(q--) {
		int l, r; cin >> l >> r;
		if(l > r) swap(l, r);
		int il = lower_bound(v.begin(), v.end(), l) - v.begin();
		int ir = upper_bound(v.begin(), v.end(), r) - v.begin();
		if(il == v.size() || il >= ir) cout << 0 << endl;
		else cout << v[ir - 1] - v[il] + 1 << endl;
	}
	
	return 0;
}

全部评论
https://ac.nowcoder.com/acm/problem/296222
点赞 回复 分享
发布于 2025-12-16 18:18 浙江

相关推荐

想去毕业旅行的斑马在...:学校不是92的话,没有实习经历投不了大厂,去投中小厂,拿点实习经历
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
正在热议
更多
# 长得好看会提高面试通过率吗? #
3376次浏览 43人参与
# HR最不可信的一句话是__ #
1038次浏览 32人参与
# 米连集团26产品管培生项目 #
7165次浏览 224人参与
# 春招至今,你的战绩如何? #
15205次浏览 141人参与
# AI面会问哪些问题? #
911次浏览 22人参与
# 你的实习产出是真实的还是包装的? #
2823次浏览 52人参与
# MiniMax求职进展汇总 #
24979次浏览 321人参与
# 沪漂/北漂你觉得哪个更苦? #
1361次浏览 40人参与
# 你做过最难的笔试是哪家公司 #
1161次浏览 20人参与
# AI时代,哪个岗位还有“活路” #
2736次浏览 50人参与
# XX请雇我工作 #
51149次浏览 171人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7982次浏览 43人参与
# 简历第一个项目做什么 #
32100次浏览 359人参与
# 简历中的项目经历要怎么写? #
310955次浏览 4260人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152854次浏览 889人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187566次浏览 1123人参与
# AI时代,哪些岗位最容易被淘汰 #
64582次浏览 867人参与
# 如果重来一次你还会读研吗 #
229990次浏览 2011人参与
# 投格力的你,拿到offer了吗? #
178284次浏览 891人参与
# 你怎么看待AI面试 #
180699次浏览 1298人参与
# 正在春招的你,也参与了去年秋招吗? #
364256次浏览 2641人参与
# 腾讯音乐求职进展汇总 #
160831次浏览 1114人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务