边工作边刷题:70天一遍leetcode: day 71-2
One Edit Distance
要点:有两种解法要考虑:已知长度和未知长度(比如只给个iterator)
- 已知长度:最好不要用if/else在最外面分情况,而是loop在外,用err记录mismatch个数,err:0,err:1,有一位mismatch,这时候再if/else分replace or ins,err:2:return False
- https://repl.it/CquW
- 错误点:index回移的logic:短的回移,因为每步必向前,所以相当于短的不动,长的动
- 未知长度:因为两个string之间char的差异最多1,所以state可以用三个变量表示:replace,ins_a,ins_b。
- 程序结构就是loop在外,然后if/else(if就是直接判断replace/ins_a/ins_b),注意这里不是按cur_a==cur_b区分。而是三个变量都是False,那么直接比较cur_a/cur_b,否则有一个True,那么就需要错位比较,然后重新把三个变量中,另外如果这个分支上再三个都是False,那说明选不可能了,return False而不是继续下一个循环。
- 循环之后?分三种情况(a多,b多 or 一样)。a多,可以是没有diff(这样多出的一个是insert的),or 有diff但是错位一直相同并且到了终点。
- 注意最后err可能在最后,类似merge,要考虑a.hasNext or b.hasNext
- https://repl.it/CsNV
- 错误点:
- 如果相同返回False,所以最后相同长度的case只能是replace为True
- 这题要用到loop的末值i,而python的loop最后的i值不是过界的,所以要用while loop
# Given two strings S and T, determine if they are both one edit distance apart.
# Hide Company Tags Snapchat Uber Facebook Twitter
# Hide Tags String
# Hide Similar Problems (H) Edit Distance
class Solution(object):
def isOneEditDistance(self, s, t):
"""
:type s: str
:type t: str
:rtype: bool
"""
if abs(len(s)-len(t))>1:
return False
error = 0
i,j = 0, 0
ns, nt = len(s), len(t)
while i<ns and j<nt:
if s[i]!=t[j]:
error+=1
if error>1:
return False
if ns>nt:
j-=1 # error: should be j-=1
elif ns<nt:
i-=1
i+=1
j+=1
return error==1 or (error==0 and ns!=nt)
sol = Solution()
assert sol.isOneEditDistance("ab","cab")==True
# Given two strings S and T, determine if they are both one edit distance apart.
# Hide Company Tags Snapchat Uber Facebook Twitter
# Hide Tags String
# Hide Similar Problems (H) Edit Distance
class Solution(object):
def isOneEditDistance(self, s, t):
"""
:type s: str
:type t: str
:rtype: bool
"""
ns, nt = len(s), len(t)
if abs(ns-nt)>1:
return False
diff, replace, ins_s, ins_t = False, False, False, False
pre = -1
i=0
while i<len(s) and i<len(t):
if not replace and not ins_s and not ins_t:
if s[i]!=t[i]:
diff=replace=ins_s=ins_t=True
else:
if ins_s and t[i]!=s[pre]: ins_s=False
if ins_t and s[i]!=t[pre]: ins_t=False
if replace and t[i]!=s[i]: replace=False
if not (ins_s or ins_t or replace): return False
pre = i
i+=1
if i<len(t):
return not diff or ((t[i]==s[pre] and ins_s) and i+1==len(t))
elif i<len(s):
return not diff or ((s[i]==t[pre] and ins_t) and i+1==len(s))
else:
return replace
sol = Solution()
assert sol.isOneEditDistance("c", "c")==False
assert sol.isOneEditDistance("a", "ba")==True
边工作边刷题:70天一遍leetcode: day 71-2的更多相关文章
- 边工作边刷题:70天一遍leetcode: day 71
Longest Substring with At Most Two Distinct Characters # Given a string, find the length of the long ...
- 边工作边刷题:70天一遍leetcode: day 89
Word Break I/II 现在看都是小case题了,一遍过了.注意这题不是np complete,dp解的time complexity可以是O(n^2) or O(nm) (取决于inner ...
- 边工作边刷题:70天一遍leetcode: day 77
Paint House I/II 要点:这题要区分房子编号i和颜色编号k:目标是某个颜色,所以min的list是上一个房子编号中所有其他颜色+当前颜色的cost https://repl.it/Chw ...
- 边工作边刷题:70天一遍leetcode: day 78
Graph Valid Tree 要点:本身题不难,关键是这题涉及几道关联题目,要清楚之间的差别和关联才能解类似题:isTree就比isCycle多了检查连通性,所以这一系列题从结构上分以下三部分 g ...
- 边工作边刷题:70天一遍leetcode: day 85-3
Zigzag Iterator 要点: 实际不是zigzag而是纵向访问 这题可以扩展到k个list,也可以扩展到只给iterator而不给list.结构上没什么区别,iterator的hasNext ...
- 边工作边刷题:70天一遍leetcode: day 101
dp/recursion的方式和是不是game无关,和game本身的规则有关:flip game不累加值,只需要一个boolean就可以.coin in a line II是从一个方向上选取,所以1d ...
- 边工作边刷题:70天一遍leetcode: day 1
(今日完成:Two Sum, Add Two Numbers, Longest Substring Without Repeating Characters, Median of Two Sorted ...
- 边工作边刷题:70天一遍leetcode: day 70
Design Phone Directory 要点:坑爹的一题,扩展的话类似LRU,但是本题的accept解直接一个set搞定 https://repl.it/Cu0j # Design a Phon ...
- 边工作边刷题:70天一遍leetcode: day 71-3
Two Sum I/II/III 要点:都是简单题,III就要注意如果value-num==num的情况,所以要count,并且count>1 https://repl.it/CrZG 错误点: ...
随机推荐
- 我所了解的WEB开发(4) - 神奇的URL
如果说WEB开发中什么最为神奇的话,我觉得这当属URL了. URL的启蒙应该是当年的互联网冲浪(surf the Internet),记得当年的电视上宣传互联网冲浪就好似今天对大数据的 ...
- javascript宿主对象之window.frames
window.frames属性是当前页面所有框架的集合.要注意的事,这里并没有frame和iframe做出区分.而且,无论页面存不存在框架,window.frames属性总是存在的,并总是指向wind ...
- CLEAR REFRESH FEEE的区别
clear,refresh,free都有用来清空内表的作用,但用法还是有区别的.clear itab,清空内表行以及工作区,但保存内存区.clear itab[],清空内表行,但不清空工作区,但保存内 ...
- Spark调优
因为Spark是内存当中的计算框架,集群中的任何资源都会让它处于瓶颈,CPU.内存.网络带宽.通常,内存足够的情况之下,网络带宽是瓶颈,这时我们就需要进行一些调优,比如用一种序列化的方式来存储RDD来 ...
- 【转】IOS高级教程1:处理1000张图片的内存优化
转载请保留以下原文链接: http://my.oschina.net/taptale/blog/91894 一.项目需求 在实际项目中,用户在上传图片时,有时会一次性上传大量的图片.在上传图片前,我们 ...
- Gradle安装
最近在学Android,而Android是由Gradle来构建的:Gradle是一个基于 JVM 的构建工具.所以开始学习Android之前,先进行Gradle安装与学习: mac: 使用SDKMAN ...
- 高仿700Bike的界面图片
下面展示本人高仿项目"700Bike"的已经完成的界面:
- 解决log4j:WARN No appenders could be found for logger (org.springframework.web.context.ContextLoader)警告信息的问题
spring项目经常在启动tomcat时报如下警告信息: log4j:WARN No appenders could be found for logger (org.springframework. ...
- swap分区
swap分区 一块的新加进来的硬盘,我们要怎么给它创建swap分区呢?要遵循下面四个步骤: (1)使用一个现有的分区,比如记为A (2)然后分区类型的16进制编码,即A的16进制编码. (3)格式化A ...
- 无法将匿名方法转换为System.Delegate
在WinForm中,不允许非UI线程访问UI,如果非UI线程需要跨线程调用UI控件,通常的解决办法是使用Control类中的Invoke方法,传递给该方法一个委托和委托调用的参数列表(params [ ...