关键字标识

题目描述

给定一个关键词集合 words 和一个字符串 inputStr,要求将 inputStr 中出现的所有关键词用标签标记:

关键词标签的起始为**,结束为** 。

把可以合并的标签进行合并,即使用最少的标签。合并规则如下:

关键词相邻则进行合并,如 ab、cd为关键词,且在字符串中相邻,则合并为 abcd

关键词相交则进行合并,如 zhi、hid为关键词,且在字符串中相交,则合并为 zhid

解答要求

时间限制:1000ms, 内存限制:256MB

输入

第1行一个整数 count,表示 words 中的关键词的个数,取值范围:[1, 64]

第2行 count 个字符串,表示关键字词列表 words,每个关键词仅含英文小写字母,长度范围:[1,16]

第3行一个字符串 inputStr,仅含英文小写字母(无空格),长度范围:[1,512]

输出

一个用最少关键词标签标记的字符串

样例

输入样例 1

java 复制代码
4
cd df op qr
opqracdfg

输出样例 1

java 复制代码
<b>opqr</b>a<b>cdf</b>g

提示样例 1

java 复制代码
关键词 op qr 出现在字符串中,且在字符串中相邻,因此可合并为 opqr;
cd df 出现在字符串中,且在字符串中相交,因此可合并为 cdf ;
其它字符保持不变。
处理后为 <b>opqr</b>a<b>cdf</b>g,使用了 2 个标签 。
<b>op</b><b>qr</b>a<b>cd</b><b>df</b>g也是一种标记方式,但关键词未作合并,需要用到 4 个标签,标签个数不是最少的。

输入样例 2

java 复制代码
3
abbb def bbg
aabbbgz

输出样例 2

java 复制代码
a<b>abbbg</b>z

提示样例 2

java 复制代码
关键字abbb和bbg合并为abbbg

Java算法源码

java 复制代码
import java.nio.charset.StandardCharsets;
import java.util.Scanner;
import java.util.HashSet;
import java.util.Scanner;

public class Main {
    // 待实现函数,在此函数中填入答题代码
    private static String getTaggedString(String[] words, String inputStr) {
        HashSet<String> wordSet = new HashSet<>(Arrays.asList(words));
        int[] result = setAllPos(wordSet, inputStr);
        if (result.length == 0) {
            return inputStr;
        }
        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < result.length; i++) {
            if (result[i] == 1) {
                sb.append("<b>").append(inputStr.charAt(i)).append("</b>");
            } else {
                sb.append(inputStr.charAt(i));
            }
        }
        String convertStr = sb.toString();
        convertStr = convertStr.replace("</b><b>", "");
        return convertStr;
    }

    private static int[] setAllPos(HashSet<String> wordSet, String inputStr) {
        int len = inputStr.length();
        int[] result = new int[inputStr.length()];
        for (int i = 0; i < len; i++) {
            for (int j = i + 1; j <= len; j++) {
                if (wordSet.contains(inputStr.substring(i, j))) {
                    for (int k = i; k < j; k++) {
                        result[k] = 1;
                    }
                }
            }
        }
        return result;
    }

    public static void main(String[] args) {
        Scanner cin = new Scanner(System.in, StandardCharsets.UTF_8.name());
        cin.nextLine();
        String[] words = cin.nextLine().split(" ");
        String inputStr = cin.nextLine();
        cin.close();

        String result = getTaggedString(words, inputStr);
        System.out.println(result);
    }
}
相关推荐
沛沛老爹4 小时前
从Web到AI:多模态Agent Skills开发实战——JavaScript+Python全栈赋能视觉/语音能力
java·开发语言·javascript·人工智能·python·安全架构
0x534 小时前
JAVA|智能仿真并发项目-进程与线程
java·开发语言·jvm
xiaolyuh1234 小时前
Spring Boot 深度解析
java·spring boot·后端
黎雁·泠崖4 小时前
Java静态方法:用法+工具类设计+ArrayUtil实战
java·开发语言
Sanyhem4 小时前
2025 年高频考点与深度追问点
java·面试
摇滚侠4 小时前
解决 IntelliJ IDEA 中 Maven 管理界面不是层级结构的问题
java·maven·intellij-idea
Mr Aokey4 小时前
RabbitMQ进阶实战:三种典型消息路由模式详解(订阅/路由/主题)
java·网络·rabbitmq
无心水5 小时前
4、Go语言程序实体详解:变量声明与常量应用【初学者指南】
java·服务器·开发语言·人工智能·python·golang·go
sheji34165 小时前
【开题答辩全过程】以 食堂兼职管理系统为例,包含答辩的问题和答案
java·eclipse
0x535 小时前
JAVA|智能仿真并发项目-并行与并发
java·开发语言