每日一练

news2024/11/29 10:53:43

这题我主要用的思想是:动态规划

1.状态表示:以i位置为结尾的字符串是否可以用字典表示,然后就可以拆分成 j ~ i 为字典中的最后一个单词,此时 0 <= j <= i (1.有可能全部为字典的一个单词,2.有可能只有一个字母的单词),然后就可以化为以 j - 1位置结尾可以被字典表示 和 j ~ i为字典中的元素,二者都符合则以i位置可以被字典表示。

2.状态转移方程: dp[i] = dp[j - 1] && string.substring(j, i + 1)

3.初始化: 防止j - 1越界,初始化dp[0] = true,然后j就只需要从1判断

4.填表顺序: 为了填写当前状态的时候,所需要的状态已经填写完成,从左到右

5.返回值: 以length - 1结尾的位置是否符合状态表示

6.细节问题: 1.hash表就可以当成字典使用,2.找到第一个能使dp[i] = true的时候就不要让j再往前找了。

public boolean wordBreak(String s, List<String> wordDict) {
        HashSet<String> hashSet = new HashSet<>(wordDict);//用于搜索
        int n = s.length();
        boolean[] dp = new boolean[n + 1];
        dp[0] = true;//防止越界,但不影响后续
        s = " " + s;//下标对应[1] 对应 [1]  处理映射
        for (int i = 0; i < n; i++) {
            // >= 1 表示不需要判断占位符
            for (int j = i; j >= 1; j--) {
                 //往前找一直找到 以j - 1结尾的能被字典所拼为止找不到直接返回false,不必判断j~i
                if (dp[j - 1] == true && hashSet.contains(s.substring(j, i + 1))){
                    dp[i] = true;
                    //只要找到一种符合条件即可 其他的无需判断
                    break;
                }else {
                    dp[i] = false;
                }
            }
        }
        return dp[n];
    }

上述代码else可以省略因为boolean的默认值是false,dp[j - 1] == true 可转换为 dp[j - 1],因为true == true 返回true,false == true  返回false。 

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【SpringBoot】返回参数

返回参数 返回页面返回数据返回 html 代码返回 json 数据两数相加用户登录 返回页面 首先在 static 文件夹中创建 index.html 文件&#xff1a; 代码&#xff1a; <html> <body><h1>hello word!!!</h1><p>this is a html page</p> <…

[C++初阶]类和对象(一)

1.面向过程和面向对象的区分 我们之前都是用C语言写的代码,我们知道C语言是一个面向过程的语言,但是现在我们学的时C,我们都知道C是一种面向对象的语言,那么什么叫面向过程?什么叫面向对象呢? 这里我们来举个例子: 比如我们是开饭店的&#xff0c;客人点了一道菜&#xff0c…

Clustering and Projected Clustering with Adaptive Neighbors 论文阅读

1 Abstract 许多聚类方法基于输入数据的相似性矩阵对数据组进行划分。因此&#xff0c;聚类结果高度依赖于数据相似性学习。由于相似性度量和数据聚类通常是分两步进行的&#xff0c;学习到的数据相似性可能不是数据聚类的最佳选择&#xff0c;从而导致次优结果。在本文中&…

2024 MathorCupB 题 甲骨文智能识别中原始拓片单字自动分割与识别研究

一、问题重述 甲骨文是我国目前已知的最早成熟的文字系统&#xff0c;它是一种刻在龟甲或兽骨上的古老文字。甲骨文具有极其重要的研究价值&#xff0c;不仅对中国文明的起源具有重要意义&#xff0c;也对世界文明的研究有着深远影响。在我国政府的大力推动下&#xff0c;甲骨…

格雷希尔G80L-T系列大口径快速连接器,在汽车膨胀水箱的气密性测试密封方案

副水箱也有人称作膨胀水箱&#xff0c;是汽车散热系统的一个重要组成部分&#xff0c;当水箱里面的温度过高的时候就会产生一定的压力&#xff0c;而副水箱可以根据热胀冷缩来帮助水箱和发动机排出去多余的水&#xff0c;起到一个调节的作用&#xff0c;副水箱由PP/PE塑料注塑而…

49.字母异位词分组(哈希字典)

《代码随想录》学习笔记&#xff0c;原链接&#xff1a;代码随想录 class Solution:def groupAnagrams(self, strs: List[str]) -> List[List[str]]:hash_table {} # 构建哈希字典result []for i in range(len(strs)): # 遍历字符串列表key "".join(s…

【攻防世界】ics-07

<?php session_start();if (!isset($_GET[page])) {show_source(__FILE__);die(); }if (isset($_GET[page]) && $_GET[page] ! index.php) {include(flag.php); }else {header(Location: ?pageflag.php); } <?phpif ($_SESSION[admin]) {$con $_POST[con];$…

Vue3——html-doc-js(html导出为word的js库)

一、下载 官方地址 html-doc-js - npm npm install html-doc-js 二、使用方法 // 使用页面中引入 import exportWord from html-doc-js// 配置项以及实现下载方法 const wrap document.getElementById(test)const config {document:document, //默认当前文档的document…

数字孪生技术在新能源行业的应用

数字孪生技术在新能源行业的应用主要体现在以下几个方面&#xff0c;数字孪生技术在新能源领域的应用有助于提高能源系统的效率和可靠性&#xff0c;推动可持续发展&#xff0c;并为新能源行业的转型升级提供坚实的技术支持。随着技术的进一步发展&#xff0c;数字孪生在新能源…

力扣 | 54. 螺旋矩阵

注意按照顺时针方向进行访问元素&#xff0c;以及每次触发的条件只会满足一个&#xff01; public List<Integer> spiralOrder(int [][] matrix){List<Integer> result new ArrayList<>();int m matrix.length;int n matrix[0].length;int row0,col 0;//…

Pytorch-张量形状操作

&#x1f606;&#x1f606;&#x1f606;感谢大家的观看&#x1f606;&#x1f606; &#x1f339; reshape 函数 transpose 和 permute 函数 view 和 contigous 函数 squeeze 和 unsqueeze 函数 在搭建网络模型时&#xff0c;掌握对张量形状的操作是非常重要的&#xff…

免费https证书申请指南——四步轻松完成

使用https协议对网站进行加密是保护网站安全的必要工作之一&#xff0c;一般情况下获取https证书&#xff0c;则需要支付费用给证书颁发机构&#xff08;CA&#xff09;。现在有一些可靠的服务提供免费的https证书&#xff0c;免费https证书遵循严格的行业标准进行颁发&#xf…

15 php学习:表单验证

表单验证 表单验证在网页和应用程序开发中起着至关重要的作用&#xff0c;其主要目的是确保用户输入的数据符合预期的格式和规则&#xff0c;以提升用户体验、数据准确性和系统安全性。以下是表单验证的主要作用&#xff1a; 数据准确性&#xff1a;通过表单验证&#xff0c;可…

C/C++ C/C++ 入门(6)模板初阶

个人主页&#xff1a;仍有未知等待探索-CSDN博客 专题分栏&#xff1a;C 多多指教&#xff01; 一、泛型编程 在之前&#xff0c;我们进行编程的时候&#xff0c;总是针对于某一个具体的问题。就比如说&#xff0c;如何实现一个int类型的swap函数呢&#xff1f;大家肯定会写。…

NLP基础—jieba分词

jieba分词 支持四种分词模式 精确模式 试图将句子最精确地切开,适合文本分析;全模式 把句子中所有的可以成词的词语都扫描出来, 速度非常快,但是不能解决歧义;搜索引擎模式 在精确模式的基础上,对长词再次切分,提高召回率,适合用于搜索引擎分词。paddle模式 利用Paddle…

渗透测试工作任务概述

一、渗透测试工作任务介绍 渗透测试工作任务不是随便用个工具就可以完成的&#xff0c;需要了解网站业务情况&#xff0c;还需要在测试结束后给出安全加固的解决方案&#xff1b; 渗透测试与入侵工具区别&#xff1a; 渗透测试&#xff1a;出于保护系统的目的&#xff0c;更全…

zehpyr环境搭建和demo的编译

qemu可执行固件编译的探索 环境demo的模拟SDK构建zephyr环境设置安装依赖项下载 Aspeed Zephyr 软件包 安装工具链配置 环境 ubuntu22.04、 qemu9.0.0-rc1、cmake 3.25.2、python 3.8.10、dtc 1.5.0、west 1.2.0、zephyr-sdk-0.16.1 demo的模拟 首先先尝试一个可以正常跑起来…

即插即用模块详解SCConv:用于特征冗余的空间和通道重构卷积

目录 一、摘要 二、创新点说明 2.1 Methodology 2.2SRU for Spatial Redundancy​编辑 2.3CRU for Channel Redundancy 三、实验 3.1基于CIFAR的图像分类 3.2基于ImageNet的图像分类 3.3对象检测 四、代码详解 五、总结 论文&#xff1a;https://openaccess.thecvf.c…

基于 Operator 部署 Prometheus 监控 k8s 集群

目录 一、环境准备 1.1 选择版本 1.2 过滤镜像 1.3 修改 yaml 镜像 1.4 移动 *networkPolicy*.yaml 1.5 修改 service 文件 1.6 提前下载镜像并推送到私有镜像仓库 1.7 修改镜像&#xff08;可选&#xff09; 二、执行创建 三、查看 pod 状态 四、访问 prometheus、…

【Spring】依赖注入(DI)时常用的注解@Autowired和@Value

目录 1、Autowired 自动装配 1.1、要实现自动装配不是一定要使用Autowired 1.2、Autowired的特性 &#xff08;1&#xff09;首先会根据类型去spring容器中找(bytype),如果有多个类型&#xff0c;会根据名字再去spring容器中找(byname) &#xff08;2&#xff09;如果根据名…