携程笔试!!!
更新:洗澡的时候好像想到问题所在了!!!因为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++。
代码如下,求大佬帮忙看看哪里没有想对!!
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++。
代码如下,求大佬帮忙看看哪里没有想对!!
全部评论
最后一题贪心就行
是不是要保证dp[i]>=0才行?
大佬能给我看下第一题的代码吗 我死活过不去 很懵逼
dp ai=0这一步也错了吧,1是自己,dpi-1是前面的,实际上还有dp(i-1-dp(i-1))
前三道简单,第四道做了一个小时没写出来,暴力过了30%
正着遍历大概率有问题
贪心85
最后一题前面的好串对后面的好串有影响,不符合dp的无后效性原则吧
大佬,第三题啥思路呀。
相关推荐
11-29 00:55
门头沟学院
牛客53210502...:简历一页:把区域银,邀请赛金标粗,其他的奖除非凑一页否则没有必要写。或者多页:每个站一行这样都列出来。项目经历看看牛客其他人是怎么写的,写的不好呢。简历打磨好按部就班没问题的 点赞 评论 收藏
分享
12-01 10:44
东北大学 Java 点赞 评论 收藏
分享
专业嗎喽:硕佬,把学校背景放后面几段,学校背景双非还学院,让人看了就不想往下看。
把实习经历和个人奖项放前面,用数字化简述自己实习的成果和掌握的技能,比如负责项目一次通过率90%,曾4次发现项目潜在问题风险为公司减少损失等等 点赞 评论 收藏
分享
