一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 481|回复: 3
收起左侧

[Leetcode] Decode Ways 求解释

[复制链接] |试试Instant~ |关注本帖
get_bits 发表于 2015-4-2 23:49:54 | 显示全部楼层 |阅读模式

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?获取更多干货,去instant注册!

x
本帖最后由 get_bits 于 2015-4-2 23:55 编辑

为什么输入序列是10的时候输出报错?
小白,求指导
跪谢了代码在二楼


 楼主| get_bits 发表于 2015-4-2 23:55:22 | 显示全部楼层
  1. class Solution {
  2. public:
  3.     int numDecodings(string s) {
  4.         if(s.size() == 0){
  5.             return 0;
  6.         }
  7.         else if(s.size() == 1)
  8.         {
  9.             return s[0] != '0' ? 1 : 0;
  10.         }
  11.         else if(s.size() == 2){
  12.             if(s[0] != '0' && s[1] == '0')
  13.             return 0;
  14.             if(s[0] != '0' && s[1] != '0' && (sum(s[0])*10 + sum(s[1])) <= 26 )
  15.             return 2;
  16.             else if (s[0] != '0' && s[1] != '0' && (sum(s[0])*10 + sum(s[1])) > 26 )
  17.             return 1;
  18.             else
  19.             return 0;
  20.         }
  21.         
  22.         int *num = new int[s.size()];
  23.         num[0] = s[0] != '0' ? 1 : 0;
  24.         num[1] = (s[0] != '0') && (s[1] != '0') + (s[0] != '0') && (s[1] != '0') && ((sum(s[0])*10 + sum(s[1])) <= 26);
  25.         
  26.         for(int i = 2; i<s.size(); i++){
  27.             num[i] = 0;
  28.             if(s[i] != '0'){
  29.             num[i] += num[i-1];
  30.             }
  31.             
  32.             if(s[i-1] != '0' && s[i] != '0' && ((sum(s[i-1])*10 + sum(s[i])) <= 26)){
  33.              num[i] += num[i-2];
  34.             }
  35.         }
  36.       return num[s.size()-1];  
  37.         
  38.     }
  39.    
  40.   int sum(char c){
  41.       return c - '0';
  42.   }
  43. };
复制代码
回复 支持 反对

使用道具 举报

碇真嗣 发表于 2015-4-3 01:16:23 | 显示全部楼层
本帖最后由 碇真嗣 于 2015-4-2 12:17 编辑

这个题不应该直接dp做吗?感觉LZ好像写烦了。。这个例子对应的貌似是12行?为啥就返回0了。。
回复 支持 反对

使用道具 举报

thevenin 发表于 2015-4-3 01:48:48 | 显示全部楼层

http://www.ninechapter.com/solutions/decode-ways/

你看看他家的解法吧,简单明了。。
回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-10 13:30

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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