12
返回列表 发新帖
楼主: 匿名
跳转到指定楼层
上一主题 下一主题
收起左侧

Google VO 后三轮

🔗
rocketdive 2022-5-22 13:50:06 | 只看该作者
全局:
最后一题 二维dp[i][j] 表示长度为i,最后一个字母为j 的数量
assume j is from [0, 25] with [0,1,2,3,4] denotes [a,e,i,o,u]

when j = 0,1,2,3,4: dp[i+1][j] = sum { dp[i][k] } | 0<=k<=25, k!=j
when j >=5: dp[i+1][j] = sum { dp[i][k] } | 0<=k<= 25

answer: dp[n][0]+dp[n][1]+dp[n][2]+...dp[n][25]
回复

使用道具 举报

地里匿名用户
🔗
匿名用户-TEDXF  2022-5-22 14:41:56 来自APP
最后一问,需要dp吗?
从0开始,找到第一个重复字符的地方,假设为k,那么这k里面长度为N的string是k-N+1个

abccdef,找N=2
第一步:abc,一共有2个。
第二步,跳到第二个c开始决定下一段为cdef,一共有3个,所以一共是5个。

回复

使用道具 举报

地里匿名用户
🔗
匿名用户-QJGQC  2022-5-24 10:13:54
如果理解错误 请指教:
最后一题为什么要用DP? 感觉sliding window就可以
每次check一下当前sliding window里面的两个character 是不是一样的 是不是vowel
如果符合条件就加一分
TC:O(n)
SC:O(1)
Follow up: 同样的sliding window(size N) and keep tracking current score in this sliding window。 每次我们只需要计算一下新进来以及移除的character对score的影响就好了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表