携程笔试9.7

贴一个t4的做法:维护前缀和,遇到0加一,遇到1减一。对于每一个左端点来说,合法的右端点是这个区间的前缀和值都大于等于左端点的前缀和值。因此考虑记录每一个位置的前缀和值,查询时二分找到左端点的第一个小于左端点的前缀和值的位置,减一下就得到对应的区间对答案的贡献。时间复杂度O(nlogn)。
全部评论
这个 s = " " + s 学到了
1 回复 分享
发布于 2023-09-07 23:49 北京
我直接把前缀数组所有项加起来就过了,没二分查找
点赞 回复 分享
发布于 2023-09-08 13:45 江西
请教一下:`查询时二分找到左端点的第一个小于左端点的前缀和值的位置` 前缀和数组不是升序数组,是怎么通过二分找到的?
点赞 回复 分享
发布于 2023-09-10 21:03 上海

相关推荐

2024-12-21 18:48
西安邮电大学 C++
黑皮白袜臭脚体育生:按使用了什么技术解决了什么问题,优化了什么性能指标来写会更好另外宣传下自己的开源仿b站微服务项目,GitHub已经390star,牛客上有完整文档教程
点赞 评论 收藏
分享
评论
6
9
分享

创作者周榜

更多
牛客网
牛客企业服务