携程笔试!!!

更新:洗澡的时候好像想到问题所在了!!!因为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 湖北

相关推荐

11-29 00:55
门头沟学院
区域赛银,邀请赛金,打算十二月打下Java基础、背点八股、写个外卖后去投福建小厂的寒假实习,简历应该怎么写呢?以及福州/和厦门有推荐的小厂吗?
牛客53210502...:简历一页:把区域银,邀请赛金标粗,其他的奖除非凑一页否则没有必要写。或者多页:每个站一行这样都列出来。项目经历看看牛客其他人是怎么写的,写的不好呢。简历打磨好按部就班没问题的
点赞 评论 收藏
分享
11-13 20:16
已编辑
厦门理工学院 软件测试
专业嗎喽:硕佬,把学校背景放后面几段,学校背景双非还学院,让人看了就不想往下看。 把实习经历和个人奖项放前面,用数字化简述自己实习的成果和掌握的技能,比如负责项目一次通过率90%,曾4次发现项目潜在问题风险为公司减少损失等等
点赞 评论 收藏
分享
评论
1
8
分享

创作者周榜

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