Golang:
思路:DP这类的题一般都不简单,需要考虑的很全面,稍有不慎就翻车,这题挂了三次,全是最简单的测试用例上,成功的把自己通过率拉到了平均线上。
这题是常态DP,没啥难度,但这题需要注意几个点:
- 字符串第一个字符如果为0,可直接返回0
- 字符串中间出现了0,那么要查看0前一位是不是1或者是2,不是可以直接返回0
代码如下:
func numDecodings(s string) int {
if len(s)==0{
return len(s)
}
if s[0]=='0' {
return 0
}
if len(s)==1{
return 1
}
arr:=make([]int,len(s))
arr[0]=1
if s[1]=='0' {
if s[0]=='1'||s[0]=='2' {
arr[1]=1
}
}else{
temp,_:=strconv.Atoi(s[0:2])
if 0<temp&&temp<27 {
arr[1]=2
}else{
arr[1]=1
}
}
for i:=2;i<len(s);i++{
if s[i]=='0'{
if s[i-1]=='1'||s[i-1]=='2'{
arr[i]=arr[i-2]
continue
}else {
return 0
}
}
if s[i-1]=='0' {
arr[i]=arr[i-1]
continue
}
t,_:=strconv.Atoi(s[i-1:i+1])
if 0<t&&t<27 {
arr[i]=arr[i-1]+arr[i-2]
}else{
arr[i]=arr[i-1]
}
}
return arr[len(arr)-1]
}
有疑问加站长微信联系(非本文作者)