leetcode刷题日记 1

https://leetcode.cn/problems/decode-ways/description/

题目分析

在这里插入图片描述

分析了一下题目,我的第一想法:和之前的上楼梯问题很像

为什么这么说呢,感觉他们的值和他们之前元素都有千丝万缕的联系

就像上楼梯问题

就是我们的dp问题

怎么解释呢?可以理解为将一个大问题分为一个一个的小问题(贪心贪一半(bushi))

我觉得dp问题的最核心的就是**:dp[i]表示什么**

像这个问题就可以将dp[i]表示成i位置是能够解码的方式有多少

其实,仔细的来看,我们每一个i位置都会面临两个情况:

  • 是否1<= s[i]<=9
  • *是否10<= s[i-1]10+s[i] <=26

这就是判断能不能将其当做一种解法的关键

否则这个i地方的数字将会dp[i]等于0

连锁反应的是是这样的话之后dp表的值都是

原理

简单来说,我们也说了,每一个s[i]都有两个情况,四种可能

如果1<= s[i]<=9的话那么这种可能的可以行得通,返回dp[i-1],证明这种方法可行

不行的话就会返回0

如果10<= s[i-1]*10+s[i] <=26,那么这种可能的可以行得通返回dp[i-2],证明这种方法可行

不行的话就会返回0

dp[i]就是将这两个可能返回的值加在一起

还要注意初始化,因为我们要用到dp[i-2],所以我们的得保证dp[i-2]不会溢出,所以当i<2时我们要单独拿出来初始化

代码如下

#define _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
#include <vector>
#include <algorithm>
#include <climits>
using namespace std;class Solution {
public:int numDecodings(string s) {vector<int> bp(s.size() + 1);int ans1 = 0;int ans2 = 0;if (s.size() == 1 && (s[0]-'0') >= 1 && (s[0] - '0') <= 9){ans1 = 1;}else ans1 = 0;bp[0] = ans1;if (s.size() == 2){if ((s[0] - '0') >= 1 && (s[0] - '0') <= 9){ans1 = 1;}else{ans1 = 0;}bp[0] = ans1 ;if ((s[1] - '0') >= 1 && (s[1] - '0') <= 9){ans1 = bp[0];}else{ans1 = 0;}if (((s[0] - '0') * 10) + (s[1] - '0') >=10  && ((s[0] - '0') * 10) + (s[1] - '0') <= 26){ans2 = bp[0];}else{ans2 = 0;}bp[1] = ans1 + ans2;}for (int i = 2; i < s.size(); i++){if ( (s[0] - '0') >= 1 && (s[0] - '0') <= 9){ans1 = 1;}else ans1 = 0;bp[0] = ans1;if ((s[1] - '0') >= 1 && (s[1] - '0') <= 9){ans1 = bp[0];}else{ans1 = 0;}if (((s[0] - '0') * 10) + (s[1] - '0') >= 10 && ((s[0] - '0') * 10) + (s[1] - '0') <= 26){ans2 =1;}else{ans2 = 0;}bp[1] = ans1 + ans2;ans1 = 0;ans2 = 0;if ((s[i] - '0') >= 1 && (s[i] - '0') <= 9){ans1 = bp[i - 1];}else{ans1 = 0;}if (((s[i-1] - '0') * 10) + (s[i] - '0') >= 10 && ((s[i-1] - '0') * 10) + (s[i] - '0') <= 26){ans2 = bp[i - 2];}else{ans2 = 0;}bp[i] = ans1 + ans2;}return bp[s.size() - 1];}
};

此系列内容只是想当一个刷题日记哈哈

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/14039.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

matlab simulink 汽车四分之一模型轮胎带阻尼

1、内容简介 略 matlab simulink121-汽车四分之一模型轮胎带阻尼 可以交流、咨询、答疑 2、内容说明 略 3、仿真分析 略 4、参考论文 略

广度优先搜索(BFS)算法详解——以走迷宫问题为例

引言&#xff1a;当算法遇见迷宫 想象你置身于一个复杂的迷宫&#xff0c;如何在最短时间内找到出口&#xff1f;这个问题不仅存在于童话故事中&#xff0c;更是计算机科学中经典的路径搜索问题。本文将带你通过走迷宫问题&#xff0c;深入理解广度优先搜索&#xff08;BFS&am…

网工_以太网MAC层

2025.02.05&#xff1a;网工老姜学习笔记 第12节 以太网MAC层 2.1 MAC层的硬件地址2.2 MAC地址特殊位含义2.3 终端适配器&#xff08;网卡&#xff09;具有过滤功能2.4 MAC帧的格式2.4.1 DIX Ethernet V2标准&#xff08;先私有&#xff0c;后开放&#xff0c;用得比较多&#…

解锁高效 Web 开发新姿势:Open WebUI 安装指南

在 Web 开发的浩瀚宇宙里&#xff0c;找到一款强大又好用的框架&#xff0c;就如同拥有了超级外挂&#xff0c;能让开发效率直线飙升。 今天要给大家介绍的 Open WebUI&#xff0c;便是这样一款神器&#xff0c;它作为开源框架&#xff0c;助力开发者轻松搭建现代感十足、交互性…

485网关数据收发测试

目录 1.UDP SERVER数据收发测试 使用产品&#xff1a; || ZQWL-GW1600NM 产品||【智嵌物联】智能网关型串口服务器 1.UDP SERVER数据收发测试 A&#xff08;TX&#xff09;连接RX B&#xff08;RX&#xff09;连接TX 打开1个网络调试助手&#xff0c;模拟用户的UDP客户端设…

软考高级-软件系统架构师-02-软件工程(重点)

用工程化的思想做软件 一、软件开发方法&#xff08;/原则&#xff09; 软件开发方法&#xff08;重点&#xff09; 结构化法&#xff08;面向过程/函数&#xff09; C 概念 用户至上严格区分工作阶段&#xff0c;每个阶段有各自的任务和成果强调系统开发的整体性和全局性系统开…

STM32的HAL库开发---通用定时器(TIMER)---定时器脉冲计数

一、脉冲计数实验原理 1、 外部时钟模式1&#xff1a;核心为蓝色部分的时基单元&#xff0c;时基单元的时钟源可以来自四种&#xff0c;分别是内部时钟PCLK、外部时钟模式1&#xff0c;外部时钟模式2、内部定时器触发&#xff08;级联&#xff09;。而脉冲计数就是使用外部时钟…

甘肃省医保刷脸设备激活步骤

医保刷脸设备激活开通操作流程 激活社保 一、拆下刷脸设备&#xff0c;按右侧按键设置Wi-Fi和内网 Wi-Fi可连接个人热点&#xff0c;用于获取安装地址 配置Wi-Fi成功以后&#xff0c;输入机构代码&#xff0c;点击“获取”&#xff0c;安装地址获取成功&#xff1b; 断开Wi-…

一个sql只能有一个order by

ORDER BY 子句在 SQL 中只能出现一次&#xff0c;静态部分和动态部分只能写一个 ORDER BY

【Linux网络编程】之守护进程

【Linux网络编程】之守护进程 进程组进程组的概念组长进程 会话会话的概念会话ID 控制终端控制终端的概念控制终端的作用会话、终端、bash三者的关系 前台进程与后台进程概念特点查看当前终端的后台进程前台进程与后台进程的切换 进程组 进程组的概念 当我们使用以下命令查与…

MySQL的底层原理与架构

前言 了解MySQL的架构和原理对于很多的后续很多的操作会有很大的帮助与理解。并且很多知识都与底层架构相关联。 了解MySQL架构 通过上面的架构图可以得知&#xff0c;Server层中主要由 连接器、查询缓存、解析器/分析器、优化器、执行器 几部分组成的&#xff0c;下面将主要…

自动化测试工具selenium的安装踩坑

先安装Python 然后pip install selenium 浏览器安装驱动 火狐版本&#xff1a;132.0 geckodriver应用W3C WebDriver兼容远程服务器与根据gecko的浏览器互动的代理&#xff0c;该程序流程出示WebDriver协议书叙述的HTTP API&#xff0c;用以与Gecko浏览器(如Firefox)通讯 下…

apisix网关ip-restriction插件使用说明

ip-restriction插件可以在网关层进行客户端请求ip拦截。 当然了&#xff0c;一般不推荐使用该方法&#xff0c;专业的事专业工具做。建议有条件&#xff0c;还是上防火墙或者waf来做。 官方文档&#xff1a;ip-restriction | Apache APISIX -- Cloud-Native API Gateway whit…

Baklib赋能数字内容体验个性化推荐提升用户体验的未来之路

内容概要 随着数字化时代的不断发展&#xff0c;用户对内容消费的需求日益多样化&#xff0c;个性化推荐成为提升用户体验的重要手段。Baklib以其先进的技术手段&#xff0c;在数字内容领域内积极推动个性化推荐的实施&#xff0c;从而满足用户在信息获取和内容消费中的独特需…

【SqlServer】SQL Server Management Studio (SSMS) 下载、安装、配置使用及卸载——保姆级教程

超详细的 SQL Server Management Studio (SSMS) 下载、安装、连接数据库配置及卸载教程 SQL Server Management Studio (SSMS) 是微软提供的图形化管理工具&#xff0c;主要用于连接、管理和开发 SQL Server 数据库。以下是详细的 SSMS 下载、安装、连接数据库以及卸载的完整教…

【慕伏白教程】Zerotier 连接与简单配置

文章目录 下载与安装 WindowsLinux apt安装官方脚本安装 Zerotier 配置 新建网络网络配置 终端配置 WindowsLinux 下载与安装 Windows 进入Zerotier官方下载网站&#xff0c;点击下载 在下载目录找到安装文件&#xff0c;双击打开后点击 Install 开始安装 安装完成后&…

BUU22 [护网杯 2018]easy_tornado 1

打开题目以后出现三个文件&#xff0c;查看源代码&#xff0c;突破口在于这三个文件都有特殊的格式 python的tornado漏洞 Tornado 是一个用 Python 编写的 Web 框架&#xff08;和flask一样&#xff0c;只不过flask是轻量级的&#xff0c;而tornado可以处理高流量&#xff09…

Windows Docker笔记-Docker拉取镜像

通过在前面的章节《安装docker》中&#xff0c;了解并安装成功了Docker&#xff0c;本章讲述如何使用Docker拉取镜像。 使用Docker&#xff0c;主要是想要创建并运行Docker容器&#xff0c;而容器又要根据Docker镜像来创建&#xff0c;那么首当其冲&#xff0c;必须要先有一个…

接入 deepseek 实现AI智能问诊

1. 准备工作 注册 DeepSeek 账号 前往 DeepSeek 官网 注册账号并获取 API Key。 创建 UniApp 项目 使用 HBuilderX 创建一个新的 UniApp 项目&#xff08;选择 Vue3 或 Vue2 模板&#xff09;。 安装依赖 如果需要在 UniApp 中使用 HTTP 请求&#xff0c;推荐使用 uni.requ…

攻防世界 文件上传

题目名称-文件包含 今天的题大概提一下解题思路就好了 这里要使用php://filter 在此基础上因为网页过滤了一些关键字 我们要进行爆破 UCS-4* UCS-4BE UCS-4LE* UCS-2 UCS-2BE UCS-2LE UTF-32* UTF-32BE* UTF-32LE* UTF-16* UTF-16BE* UTF-16LE* UTF-7 UTF7-IMAP UTF-8* ASCII…