力扣0091——解码方法

解码方法

难度:中等

题目描述

一条包含字母 A-Z 的消息通过以下映射进行了 编码

'A' -> "1"

'B' -> "2"

...

'Z' -> "26"

解码 已编码的消息,所有数字必须基于上述映射的方法,反向映射回字母(可能有多种方法)。例如,"11106" 可以映射为:

  • "AAJF" ,将消息分组为 (1 1 10 6)
  • "KJF" ,将消息分组为 (11 10 6)

注意,消息不能分组为 (1 11 06) ,因为 "06" 不能映射为 "F" ,这是由于 "6""06" 在映射中并不等价。

给你一个只含数字的 非空 字符串 s ,请计算并返回 解码 方法的 总数

题目数据保证答案肯定是一个 32 位 的整数。

示例1

输入: s = "12"
输出: 2

示例2

输入: s = "226"
输出: 3

示例3

输入: s = "06"
输出: 0

题解

依题意得,编码得第一个数字不能为1,则可分为以下部分:

  • s[0] == '0',那么直接返回0
  • 之后由第二个元素开始遍历
    • 当当前元素为0,那么前一个元素只能为两种情况:
      • 当前一个元素为12时,只有一种解法
      • 当前一个元素不为上述两个数,则没有解法
    • 当当前元素为12并且前一个元素和当前元素拼接的数字不大于26
      • 有两种解法

最后将遍历结束的值返回即为所求

想法代码

csharp 复制代码
class Solution
{
    public static void Main(String[] args)
    {
        string s = "27";
        Solution solution = new Solution();
        int ans = solution.NumDecodings(s);
        Console.WriteLine(ans);
    }

    public int NumDecodings(string s)
    {
        if (s[0] == '0')
        {
            return 0;
        }
        int pre = 1;
        int curr = 1;
        for (int i = 1; i < s.Length; i++)
        {
            int temp = curr;
            if (s[i] == '0')
            {
                if (s[i - 1] == '1' || s[i - 1] == '2')
                {
                    curr = pre;
                }
                else
                {
                    return 0;
                }
            }

            else if (s[i - 1] == '1' || s[i - 1] == '2' && (s[i - 1] - '0') * 10 + (s[i] - '0') <= 26)
            {
                curr = curr + pre;
            }
            pre = temp;
        }
        return curr;
    }
}
相关推荐
代码游侠1 小时前
日历的各种C语言实现方法
c语言·开发语言·学习·算法
春日见5 小时前
丝滑快速拓展随机树 S-RRT(Smoothly RRT)算法核心原理与完整流程
人工智能·算法·机器学习·路径规划算法·s-rrt
Code小翊5 小时前
”回调“高级
算法·青少年编程
云里雾里!5 小时前
力扣 977. 有序数组的平方:双指针法的优雅解法
算法·leetcode·职场和发展
一只侯子8 小时前
Face AE Tuning
图像处理·笔记·学习·算法·计算机视觉
jianqiang.xue8 小时前
别把 Scratch 当 “动画玩具”!图形化编程是算法思维的最佳启蒙
人工智能·算法·青少年编程·机器人·少儿编程
不许哈哈哈9 小时前
Python数据结构
数据结构·算法·排序算法
J***793910 小时前
后端在分布式系统中的数据分片
算法·哈希算法
天真小巫10 小时前
2025.11.28总结
职场和发展
Dream it possible!11 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树中第 K 小的元素(86_230_C++_中等)
c++·leetcode·面试