【2023美团后端-8】删除字符串的方案,限制不能连续删

小美定义一个字符申是"美丽串",当且仅当该字符串包含"mei"连续子串。例如"meimei"、"xiaomeichan"都是美丽串,现在小美拿到了一个字符串,她准备删除一些字符,但不能删除两个连续字符。小美希望最终字符串变成美丽串,她想知道有多少种删除方案?

输入描述

一个仅包含小写字母的字符串,长度不超过 20。

输出描述

删除的方案数

示例1

input

meili

output

3

解释: 可以删除l,i,或者不删.共3种.

思路:

暴力搜索,

preDeleted记录前序的状态,false表示未操作,true表示删除.

having记录当前拥有了几个序列.

base case: 字符串遍历结束.

注意: 初始为[0,false,0], 遇到m直接置1,having=3随便操作,having<3,选用了其他字符,having置0.

代码题解

复制代码
import java.util.*;

public class test {
    static int len = 0;
    static String str = "";
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        str = sc.nextLine();
        // 遍历字符串,找到连续的 "mei" 子串
        len = str.length();
        int count = dfs(0,false,0);
        System.out.println(count);
    }

    /**
     * 深搜
     * @param index 当前i
     * @param preDeleted 标前一个是否删除
     * @param having 拥有mei的数量 遇到m给1,1后遇到e给2..
     * @return 数量
     */
    private static int dfs(int index, boolean preDeleted, int having) {
        if (index >= len) {
            if (having==3) {
                return 1;
            }
            return 0;
        }
        if (preDeleted) {//前序删除,所以当前直接跳过不删
            return calCount(index,having);
        } else {//删除+不删
            int tmp = dfs(index + 1, true, having);//删除
            return calCount(index,having)+tmp;
        }
    }

    /**
     * 处理状态的转换
     * @param index
     * @param having
     * @return
     */
    private static int calCount(int index, int having) {
        if ((having==0||having==1||having==2) && str.charAt(index)=='m') {
            return dfs(index+1,false,1);//遇到m则having置1
        } else if (having==1 && str.charAt(index)=='e') {
            return dfs(index+1,false,2);//遇到e则having置2
        } else if ((having==2 && str.charAt(index)=='i')||having==3) {
            return dfs(index+1,false,3);//遇到e则having置2
        } else
            return dfs(index+1,false,0);//选了其他则having置0
    }

}
相关推荐
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 68: 猜数字大小II、矩阵中的最长递增路径
数据结构·算法·leetcode·职场和发展·贪心算法·矩阵·深度优先
灵感__idea3 小时前
Hello 算法:让前端人真正理解算法
前端·javascript·算法
学习2年半4 小时前
小米笔试题:一元一次方程求解
算法
MATLAB代码顾问4 小时前
MATLAB绘制多种混沌系统
人工智能·算法·matlab
极客BIM工作室4 小时前
演化搜索与群集智能:五种经典算法探秘
人工智能·算法·机器学习
qq_574656255 小时前
java-代码随想录第66天|Floyd 算法、A * 算法精讲 (A star算法)
java·算法·leetcode·图论
金融街小单纯5 小时前
从蓝军建设中学习颠覆性质疑思维
人工智能·算法·机器学习
少许极端6 小时前
算法奇妙屋(五)-链表
数据结构·算法·链表
XISHI_TIANLAN7 小时前
【多模态学习】Q&A6: 什么是MOE架构?Router Z Loss函数是指什么?负载均衡损失(Load Balancing Loss)又是什么?
学习·算法·语言模型
木子.李3477 小时前
数据结构-算法C++(额外问题汇总)
数据结构·c++·算法