【每日一题】4月14日题目精讲 枚举

题号 NC14247
名称 Xorto
来源 Wannafly挑战赛1
戳我进入往期每日一题汇总贴~
注:如果你在题库做题时遇到了喜欢的题目,欢迎推荐给邓老师~ 点击查看详情

题目描述

给定一个长度为 的整数数组,问有多少对互不重叠的非空区间,使得两个区间内的数的异或和为

输入描述

第一行一个数 表示数组长度;
第二行 个整数表示数组; ,

输出描述

一行一个整数表示答案。

示例1

输入

3
0 0 0

输出

5

说明

([1,1],[2,2]),([1,1],[3,3]),([1,1],[2,3]),([1,2],[3,3]),([2,2],[3,3])


图片说明

题解

暴力是枚举两个区间左右端点,但是显而易见会tle,我们可以考虑只枚举其中一个区间[x,y],这个区间的异或和可以很容易的在O(1)时间复杂度通过前缀异或和求得。如果我们规定[x,y]是右边的那个区间,实际上我们需要知道的是,左边有多少个区间的异或和与[x,y]的异或和相等。
我们可以用一个类似桶排序的桶的数组cnt[i]来表示当前位置左边异或和为i的区间的个数,这个当前位置其实是就是上面那个x。而显然以x-1为右界的区间在之前就统计了,所以我们只需要再枚举一个j,表示i为右界的时候区间的左界,然后把区间的情况都加入到cnt数组里。这个j的枚举和上面y的枚举是并列的,算法时间复杂度是

看完邓老师的题解,记得去做题提高呀~
欢迎各位大佬来做题写题解,也欢迎大家踊跃在当日讨论贴中提问!

活动奖励:

在牛客博客中写出题解,并回复地址
审核通过可获得(依据题目难度和题解的内容而定)

本道题目4月21日中午12:00之前写的题解有获得牛币资格~

.牛币兑换中心

牛客博客开通方式

  1. 如何开通牛客博客:https://www.nowcoder.com/discuss/202952
  2. 如何使用博客搬家功能:进入博客--->设置--->底部博客搬家
  3. 如果你对牛客博客有任何意见或建议:牛客博客意见反馈专贴
全部评论
https://blog.nowcoder.net/n/8e07d9fac5464b8eb1bec8a7411f3422
1 回复 分享
发布于 2020-04-14 23:26
https://blog.nowcoder.net/n/b7029b7d0c034b43ad968171621e0063
1 回复 分享
发布于 2020-04-13 12:22
https://blog.nowcoder.net/n/ddf2b5244a2b4d0fbf02ed062e013402
点赞 回复 分享
发布于 2020-04-20 21:08
https://blog.nowcoder.net/n/fe4407ba67884db581f58be3b6d1f206
点赞 回复 分享
发布于 2020-04-19 11:06
给的范围小了吧 https://blog.nowcoder.net/n/268f1147fa424c65a2939bcec51dd657
点赞 回复 分享
发布于 2020-04-18 11:25
https://blog.nowcoder.net/n/523635de92654a81b942268e14e8ad07
点赞 回复 分享
发布于 2020-04-17 15:57
https://blog.nowcoder.net/n/fb8e9ecde4834df28338d51f4c1290a0
点赞 回复 分享
发布于 2020-04-16 23:45
https://blog.nowcoder.net/n/182c1cb7723f4ef1a864075889502936
点赞 回复 分享
发布于 2020-04-16 23:25
https://blog.nowcoder.net/n/7dfab4384ed6438c84e297854e293033
点赞 回复 分享
发布于 2020-04-16 22:45
https://blog.nowcoder.net/n/f9f881b0d3e44bd1bc6500678e1feba9
点赞 回复 分享
发布于 2020-04-16 15:17
https://blog.nowcoder.net/n/490397c5a76443ee8e45415255732d8a
点赞 回复 分享
发布于 2020-04-16 14:37
https://blog.nowcoder.net/n/a755d7d51bb94f6bbf575883c5a5c157
点赞 回复 分享
发布于 2020-04-15 15:30
https://blog.nowcoder.net/n/15b1a06dbda54ad3bc457db94b6300ac
点赞 回复 分享
发布于 2020-04-15 14:34
https://blog.nowcoder.net/n/4a2467a2ec744b899d90402047f0c720
点赞 回复 分享
发布于 2020-04-15 09:47
https://blog.nowcoder.net/n/5d255480afed43d797e4d9e675d82af9
点赞 回复 分享
发布于 2020-04-14 18:44
https://blog.nowcoder.net/n/34064236e53e4f298d76a874dab25e76
点赞 回复 分享
发布于 2020-04-14 15:44
https://blog.nowcoder.net/n/b7cf67a1a55a483dab95fcfc02e7384f
点赞 回复 分享
发布于 2020-04-14 14:20
https://blog.nowcoder.net/n/306b261115d84e13bc98f7b2bde7668e
点赞 回复 分享
发布于 2020-04-14 11:27
https://blog.nowcoder.net/n/c1f0e8ed5100450fb8b83d223c68b9cf
点赞 回复 分享
发布于 2020-04-13 23:00
https://blog.nowcoder.net/n/f24d4d6fa56f4fd18f0111904fc4eeff
点赞 回复 分享
发布于 2020-04-13 21:15

相关推荐

点赞 评论 收藏
分享
“无名小卒,还是名扬天下?”我知道很多人都不觉得我能走到今天这一步,当然,也包括我自己。在我的人生里,有两部作品刻下了最深的烙印:《斗破苍穹》与《龙族》。它们总被人拿来对照:一边是萧炎的桀骜轻狂,一边是路明非的怯懦衰颓。有人说,天蚕土豆没见过魂天帝,但江南见过真凯撒。我时常觉得,自己就是那个衰小孩路明非。可路明非可以开挂,我不可以;我也无数次幻想过,能拥有萧炎那般年少轻狂的人生,可我没有他与生俱来的逆天天赋。我只是个平庸的普通人,一个看过《斗破苍穹》却开不了挂的路明非,只能一步一步往上爬。从我下定决心找实习的那一刻起,我就给自己定下了目标:“我一定要为字节跳动卖命.jpg”。萧炎有他的三年之约,我有我的两年半之约(其实是一年半)。2024.11.20,科大讯飞的第一封实习offer落进邮箱,我迈出了这场奔赴的第一步。2025.8.18,放弃百度转正的安稳机会,转身走进前路未卜的不确定里。2025.11.14,我选择走进字节跳动,以实习生的身份重新出发。2026.3.25 - 3.31,一周速通上海飞书,幸遇赏识我的伯乐,斩获Special Offer。被告知面试通过的那一刻,我的内心无比平静,就像这个offer本就该属于我。不是侥幸,是应得的。这一路,有人看轻过我的出身,不相信我能走到这里;也有人在我看不见前路的时候,替我举过灯。没有他们的鼓励与支撑,就没有今天站在这里的我。我看到了自强不息的激荡,那是一个双非的伟大乐章!我是雨夜迈巴赫,我要开启属于我的新篇章了。
在看牛客的本杰明很勇...:真心祝贺l总 我永远的偶像 我滴神
春招至今,你收到几个面试...
点赞 评论 收藏
分享
评论
5
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务