携程笔试!!!

更新:洗澡的时候好像想到问题所在了!!!因为map里只能存好串的差值,所以每次要把已经失效的值删去!!!改了这个应该就对了吧,如p2

A了3.2,最后一题想不出为什么只能过20%。。
我的思路是求dp[i]表示以i结尾的子串中好串的数量,最后累加。
如果a[i]=0,那么dp[i]=dp[i-1]+1;如果a[i]=1,那么dp[i]=dp[i-1]-(以i-1结尾的好子串中,0的数量减去1的数量等于1的串的数量),要求这个差值,暴力就是每次都要把一个记录差值的数组左移右移,然后我就用了一个offset偏移量永远指向差值为0,如果来0就是右移,offset--,如果来0就是左移,offset++。
代码如下,求大佬帮忙看看哪里没有想对!!
全部评论
最后一题贪心就行
11 回复 分享
发布于 2023-09-07 21:25 江苏
是不是要保证dp[i]>=0才行?
点赞 回复 分享
发布于 2023-09-07 21:31 北京
大佬能给我看下第一题的代码吗 我死活过不去 很懵逼
点赞 回复 分享
发布于 2023-09-07 21:23 广东
dp ai=0这一步也错了吧,1是自己,dpi-1是前面的,实际上还有dp(i-1-dp(i-1))
点赞 回复 分享
发布于 2023-09-07 21:23 广东
前三道简单,第四道做了一个小时没写出来,暴力过了30%
点赞 回复 分享
发布于 2023-09-07 21:19 湖北
正着遍历大概率有问题
点赞 回复 分享
发布于 2023-09-07 21:15 广东
贪心85
点赞 回复 分享
发布于 2023-09-07 21:14 上海
最后一题前面的好串对后面的好串有影响,不符合dp的无后效性原则吧
点赞 回复 分享
发布于 2023-09-07 21:12 山东
大佬,第三题啥思路呀。
点赞 回复 分享
发布于 2023-09-07 21:11 湖北

相关推荐

亲切的00后在笔试:我也遇到了,所以我早他一步查看图片
点赞 评论 收藏
分享
评论
1
8
分享

创作者周榜

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