关键字标识

2024-05-09 13:52
文章标签 关键字 标识

本文主要是介绍关键字标识,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

给定一个关键词集合 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

4
cd df op qr
opqracdfg

输出样例 1

<b>opqr</b>a<b>cdf</b>g

提示样例 1

关键词 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

3
abbb def bbg
aabbbgz

输出样例 2

a<b>abbbg</b>z

提示样例 2

关键字abbb和bbg合并为abbbg

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);}
}

这篇关于关键字标识的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973581

相关文章

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

c# checked和unchecked关键字的使用

《c#checked和unchecked关键字的使用》C#中的checked关键字用于启用整数运算的溢出检查,可以捕获并抛出System.OverflowException异常,而unchecked... 目录在 C# 中,checked 关键字用于启用整数运算的溢出检查。默认情况下,C# 的整数运算不会自

Oracle Start With关键字

Oracle Start With关键字 前言 旨在记录一些Oracle使用中遇到的各种各样的问题. 同时希望能帮到和我遇到同样问题的人. Start With (树查询) 问题描述: 在数据库中, 有一种比较常见得 设计模式, 层级结构 设计模式, 具体到 Oracle table中, 字段特点如下: ID, DSC, PID; 三个字段, 分别表示 当前标识的 ID(主键), DSC 当

关键字synchronized、volatile的比较

关键字volatile是线程同步的轻量级实现,所以volatile性能肯定比synchronized要好,并且volatile只能修饰于变量,而synchronized可以修饰方法,以及代码块。随着JDK新版本的发布,synchronized关键字的执行效率上得到很大提升,在开发中使用synchronized关键字的比率还是比较大的。多线程访问volatile不会发生阻塞,而synchronize

JavaScript 根据关键字匹配数组项

要在JavaScript数组中根据关键字匹配项,可以使用filter方法结合一个测试函数。以下是一个示例代码,定义了一个函数findByKeyword,该函数接受一个数组和一个关键字,然后返回一个新数组,其中包含与关键字匹配的所有项。 function findByKeyword(array, keyword) {return array.filter(item => {// 假设要匹配的是对象

MySQL 的关键字

MySQL 中的关键字是数据库中具有特殊含义的保留字,它们用于定义数据库结构、操作数据库数据和控制数据库行为。关键字在 MySQL 查询中扮演着至关重要的角色,因为它们是 SQL 语句的核心组成部分。 1. 数据定义语言 (DDL) 关键字 数据定义语言 (DDL) 关键字用于定义、修改和删除数据库结构,如数据库、表和索引等。这些关键字通常用于创建、删除表结构以及修改表的列等操作。 1.1

C++中的mutable关键字详解

目录 1.概述 2.使用场景 3.示例 4.mutable修饰Lambda表达式 5.注意事项 1.概述         在C++中,mutable也是为了突破const的限制而设置的。被mutable修饰的变量,将永远处于可变的状态,即使在一个const函数中。         我们知道,被const关键字修饰的函数的一个重要作用就是为了能够保护类中的成员变量。即:该函数可以

[Python]生成器和yield关键字

生成器和yield关键字 1.生成器介绍: 概述: ​ 它指的是 generator, 类似于以前学过的: 列表推导式, 集合推导式, 字典推导式… 作用: ​ 降低资源消耗, 快速(批量)生成数据. 实现方式: ​ 1.推导式写法. my_generator = (i for i in range(5)) ​ 2.yield写法. def get_generator():for i

java基础总结11-面向对象7(super关键字)

在JAVA类中使用super来引用父类的成分,用this来引用当前对象,如果一个类从另外一个类继承,我们new这个子类的实例对象的时候,这个子类对象里面会有一个父类对象。怎么去引用里面的父类对象呢?使用super来引用,this指的是当前对象的引用,super是当前对象里面的父对象的引用。 1 super关键字测试 package cn.galc.test;/*** 父类* @autho

java基础总结08-面向对象4(static关键字)

原来一个类里面的成员变量,每new一个对象,这个对象就有一份自己的成员变量,因为这些成员变量都不是静态成员变量。对于static成员变量来说,这个成员变量只有一份,而且这一份是这个类所有的对象共享。 静态成员变量与非静态成员变量的区别 以下面的例子为例说明 package cn.galc.test;public class Cat {/*** 静态成员变量*/private static