首页 > 其他分享 >leetcode 2707. 字符串中的额外字符

leetcode 2707. 字符串中的额外字符

时间:2023-05-30 16:57:46浏览次数:61  
标签:字符 下标 dictionary int 2707 length 字符串 leetcode

2707. 字符串中的额外字符

给你一个下标从 0 开始的字符串 s 和一个单词字典 dictionary 。你需要将 s 分割成若干个 互不重叠 的子字符串,每个子字符串都在 dictionary 中出现过。s 中可能会有一些 额外的字符 不在任何子字符串中。

请你采取最优策略分割 s ,使剩下的字符 最少 。

示例 1:

输入:s = "leetscode", dictionary = ["leet","code","leetcode"]
输出:1
解释:将 s 分成两个子字符串:下标从 0 到 3 的 "leet" 和下标从 5 到 8 的 "code" 。只有 1 个字符没有使用(下标为 4),所以我们返回 1 。

示例 2:

输入:s = "sayhelloworld", dictionary = ["hello","world"]
输出:3
解释:将 s 分成两个子字符串:下标从 3 到 7 的 "hello" 和下标从 8 到 12 的 "world" 。下标为 0 ,1 和 2 的字符没有使用,所以我们返回 3 。

提示:

  • 1 <= s.length <= 50
  • 1 <= dictionary.length <= 50
  • 1 <= dictionary[i].length <= 50
  • dictionary[i] 和 s 只包含小写英文字母。
  • dictionary 中的单词互不相同。

解题思路:

此题本身应该是采用字典树来完成的,但是看数据量不大,n^4的情况下,理论上是可以完成的,所以此处直接暴力解题。
1.双层编辑字符串, 截取的子串(i, j);
2.定义二维数组arr, arr[i][j] 表示字符串i - j 最少剩下的字符。最终的答案为arr[0][s.length - 1];
3.遍历dictionary,自从头尾各匹配一次,若是匹配上,则更新最小值。
最终勉强能过,以后测试用例多了,可能就过不了了。

class Solution {
    public int minExtraChar(String s, String[] dictionary) {
        int length = s.length();
        int[][] arr = new int[length][length];
        for (int i = length - 1; i >= 0; i--) {
            for (int j = i + 1; j <= length; j++) {
                String sub = s.substring(i, j);
                int min = j - i;
                for (String d : dictionary) {
                    if (sub.startsWith(d)) {
                        if (i + d.length() == j) {
                            min = 0;
                            break;
                        }
                        min = Math.min(min, arr[i + d.length()][j - 1]);
                    }
                    if (sub.endsWith(d)) {
                        min = Math.min(min, arr[i][j - 1 - d.length()]);
                    }
                }
                if (i < j - 1) {
                    min = Math.min(min, Math.min(arr[i + 1][j - 1] + 1, arr[i][j - 2] + 1));
                }
                arr[i][j - 1] = min;

            }
        }
        return arr[0][length - 1];
    }
}

 

 

标签:字符,下标,dictionary,int,2707,length,字符串,leetcode
From: https://www.cnblogs.com/wangzaiguli/p/17443700.html

相关文章

  • jquery本地存储的数据格式只能是字符串,如需存储对象,需要转换后存储
    <!DOCTYPEhtml><htmllang="en"> <head> <metacharset="UTF-8"> <title>Title</title> <scriptsrc="js/jquery-3.5.1.min.js"></script> </head> <body> <scri......
  • 3.1. 字符串与StringBuilder
    1.字符串(String)在Java中,字符串由String类表示。字符串是一系列字符的组合,用于表示文本数据。字符串是不可变的,这意味着一旦创建了一个字符串对象,就不能修改它的内容。创建字符串创建字符串的方式有两种:直接使用双引号("")创建字符串字面量。例如:Stringstr1="Hello,World!......
  • [LeetCode] 51. N-Queens
    The n-queens puzzleistheproblemofplacing n queensonan nxn chessboardsuchthatnotwoqueensattackeachother.Givenaninteger n,return alldistinctsolutionstothe n-queenspuzzle.Youmayreturntheanswerin anyorder.Eachsolution......
  • 【python】字符串
    字符串startwithstartswith()方法用于检查字符串是否是以指定子字符串开头,如果是则返回True,否则返回False。如果参数beg和end指定值,则在指定范围内检查。语法:str.startswith(substr,beg=0,end=len(string));参数str:检测的字符串。substr:指定的子字符串。beg:可选......
  • #yyds干货盘点# LeetCode程序员面试金典:填充每个节点的下一个右侧节点指针 II
    题目:给定一个二叉树:structNode{ intval; Node*left; Node*right; Node*next;}填充它的每个next指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将next指针设置为NULL。初始状态下,所有 next指针都被设置为NULL。 示例1:输入:root=[1,2,3......
  • 用自然语言让AI打leetcode周赛
    还在自己吭哧吭哧打算法平台Leetcode的周赛?为什么不试试神奇的ChatGPT类AI呢!用AI助手Claude参加第103场周赛,共四道题,均完成了AC,能达到参与者前10%的成绩。事情的起因是知乎上一位叫萧雅的用户尝试使用AI进行编程,但在测试过程中,她发现直接给出题目让AI进行编程并输出结果的方法,效......
  • 字符串类型内置方法
    一、字符串类型内置方法(str)1.用途:描述性质的东西,如人的名字、单个爱好、地址、国家等2.定义:使用''、""、''''''、""""""包裹的的一串字符u'unicode':unicode编码的字符串b'101':二进制编码的字符串r'\n':原生字符串,也就是说......
  • LeetCode 530. 二叉搜索树的最小绝对差
    题目链接:LeetCode530.二叉搜索树的最小绝对差题意:给你一个二叉搜索树的根节点root,返回树中任意两不同节点值之间的最小差值。差值是一个正数,其数值等于两值之差的绝对值。解题思路:递归法1既然是二叉搜索树,那么中序遍历一定是有序的,因此最小的插值一定出现在相邻的两个......
  • v-if 判断是否包含字符串
    <el-buttonv-if="!table.name.includes('模板')"type="danger"size="mini"@click="deleteTempalte(table)">删除</el-button> <trv-for="(subsidy,i......
  • LeetCode 98. 验证二叉搜索树
    题目链接:LeetCode98.验证二叉搜索树题意:给你一个二叉树的根节点root,判断其是否是一个有效的二叉搜索树。有效二叉搜索树定义如下:节点的左子树只包含小于当前节点的数。节点的右子树只包含大于当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。解题思路......