当前位置: 首页 > news >正文

做网站需要哪几个板块第1 ppt模板网

做网站需要哪几个板块,第1 ppt模板网,godaddy绑定wordpress,wordpress电商平台插件题目描述 给定一个连续不包含空格字符的字符串,该字符串仅包含英文小写字母及英文标点符号(逗号、句号、分号),同时给定词库,对该字符串进行精确分词。 说明:精确分词:字符串分词后,…

alt

题目描述

给定一个连续不包含空格字符的字符串,该字符串仅包含英文小写字母及英文标点符号(逗号、句号、分号),同时给定词库,对该字符串进行精确分词。

说明:

  • 精确分词:字符串分词后,不会出现重叠。例如 “ilovechina”,不同切分后可得到 “i”, “love”, “china”。

  • 标点符号不分词,仅用于断句。

  • 词库:根据常识及词库统计出来的常用词汇。例如:dictionary={“i”,“love”,“china”,“ilovechina”,“lovechina”}。

  • 分词原则:采用分词顺序优先且最长匹配原则。“ilovechina”,假设分词结果[i,ilove,lo,love,ch,china,lovechina] 则输出 [ilove,china]

    • 错误输出:[i, lovechina],原因:“ilove” > 优先于 “lovechina” 成词。
    • 错误输出:[i, love, china],原因:“ilove” > “i”,遵循最长匹配原则。

输入描述

  1. 字符串长度限制:0 < length < 256
  2. 词库长度限制:0 < length < 100000
  3. 第一行输入待分词语句 “ilovechina”
  4. 第二行输入中文词库 “i, love, china, ch, na, ve, lo, this, is, the, word”

输出描述

按顺序输出分词结果 “i, love, china”

示例1

输入:
ilovechina
i,love,china,ch,na,ve,lo,this,is,the,word输出:
i,love,china说明:
输入的字符串被按最长匹配原则分为 "i", "love", "china"。

示例2

输入:
ilovech
i,love,china,ch,na,ve,lo,this,is,the,word输出:
i,love,ch说明:
输入的字符串被按最长匹配原则分为 "i", "love", "ch"。

题解

这道题目属于字符串处理和字典树(Trie)应用的题目。题解思路如下:

  1. 构建字典树(Trie)
    • 使用字典树来存储词库中的单词,方便高效地进行查找和匹配。
  2. 分词过程
    • 对输入的字符串进行遍历,从当前位置向后进行匹配。
    • 尽量匹配最长的单词,如果匹配成功,则将该单词加入结果列表。
    • 如果没有匹配到词库中的任何单词,则将当前字符作为一个单词加入结果列表。
  3. 时间复杂度
    • 构建字典树的时间复杂度是 O(n),其中 n 为词库中所有单词的总长度。
    • 分词的时间复杂度是 O(m),其中 m 为待分词字符串的长度。
  4. 空间复杂度
    • 字典树的空间复杂度是 O(n),其中 n 为词库中所有单词的总长度。

Java

import java.util.*;
/*** @author code5bug*/
class TrieNode {Map<Character, TrieNode> children = new HashMap<>();boolean isEndOfWord = false;
}class Trie {private final TrieNode root;public Trie() {root = new TrieNode();}public void insert(String word) {TrieNode node = root;for (char ch : word.toCharArray()) {node.children.putIfAbsent(ch, new TrieNode());node = node.children.get(ch);}node.isEndOfWord = true;}public List<String> searchAll(String text) {List<String> result = new ArrayList<>();int length = text.length();for (int i = 0; i < length; ) {TrieNode node = root;int longestMatch = -1;for (int j = i; j < length; j++) {char ch = text.charAt(j);if (!node.children.containsKey(ch)) {break;}node = node.children.get(ch);if (node.isEndOfWord) {longestMatch = j;}}if (longestMatch == -1) {result.add(text.substring(i, i + 1));i++;} else {result.add(text.substring(i, longestMatch + 1));i = longestMatch + 1;}}return result;}
}public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);String text = scanner.nextLine().trim();String[] dictionaryWords = scanner.nextLine().trim().split(",");Trie trie = new Trie();for (String word : dictionaryWords) {trie.insert(word);}List<String> segmentedWords = trie.searchAll(text);System.out.println(String.join(",", segmentedWords));}
}

希望这个专栏不仅能帮您成功通过华为机试,还能让您熟练掌握算法。

整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

http://www.dtcms.com/a/449015.html

相关文章:

  • 做网站排名步骤电子商务网站开发策划案
  • 如何打破违法网站建设企业银行u盾如何使用
  • 太原网站制作优化seo重庆渝中区企业网站建设哪家专业
  • 国外移动端网站模板做自己的网站要钱么
  • 上海做高端网站制作服务公司商标
  • 北京电力建设公司培训学校网站旅业认证二维码有什么用
  • 网站的图片怎么做无锡网站建设价格
  • 代账公司注册条件宜昌做网站优化
  • 合肥网站建设公司还有不江苏建设人才网站
  • 企业邮箱注册申请步骤seo图片
  • 安徽省建设工程信息网站进不了刷网站关键词排名原理
  • 河北 建设厅网站首页手机网页视频怎么下载
  • 涡阳哪里有做网站的查看网站开发语言方法
  • 个人网站欣赏的网站什么是网站建设规划书
  • 校园网站建设的要素wordpress获取自定义字段的值
  • 影视网站代理备案 网站首页网址
  • 网站建设中古典武侠中文字幕电子商务网站建设实训报告主要内容
  • 网站开发要学哪些知识湖南旅游网站开发
  • 微信小网站怎么做上海广告牌制作公司
  • 网站建设主要内容成都有什么好玩的地方景点
  • 连接国外网站做端口映射如何做整人网站
  • 西宁做网站公司建设论坛网站步骤
  • 婚庆公司一般收费标准邢台抖音优化
  • 环保企业网站模板代理公司英文
  • 查询网站开发语言排网站排名查询系统
  • 张家港做企业网站加强政协网站建设
  • 仿门户网站多功能js相册画廊源码上海市建设合同信息表网站
  • 苗木网站怎么做网站建设推荐北京华网天下
  • 怎么成立个人网站网页ui设计作品欣赏
  • 学会网站开发有什么好处打开手机网站速度慢