200330题(820.单词的压缩编码(字典树))

2023-11-30 09:08

本文主要是介绍200330题(820.单词的压缩编码(字典树)),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述
从0位置开始遍历字符串S,遇到#停止,得到time 从2位置开始遍历字符串S,遇到#停止,得到me 从5位置开始遍历字符串S,遇到#停止,得到bell.

字典树的建立详见实现 Trie (前缀树、字典树)

法1思路:字典树:根据列表中单词的长度由长到短进行排序,排好序后对每个单词反转顺序,最后再插入字典树,插入时通过标志位isNew判断是否为新单词即可。

class Trie {
private:bool isEnd;Trie* next[26];
public:Trie(){isEnd = false;memset(next, 0, sizeof(next));}int insert(string word) {bool isNew = false;//判断是否为新单词Trie* node = this;for (char c : word){if (node->next[c - 'a'] == NULL){node->next[c - 'a'] = new Trie();isNew = true;//是新单词(因为创建了新结点,所以是新单词)}node = node->next[c - 'a'];}node->isEnd = true;return isNew ? word.length() + 1 : 0;//+1是因为还有#}};class Solution {
public:bool static cmp(const string str1, const string str2){return str1.length() > str2.length();}int minimumLengthEncoding(vector<string>& words){Trie*trie = new Trie();//根据列表中单词的长度由长到短进行排序,排好序后对每个单词反转顺序,最后再插入字典树sort(words.begin(), words.end(), cmp);for (int i = 0; i < words.size(); i++){reverse(words[i].begin(), words[i].end());}int res = 0;for (string word : words){res += trie->insert(word);}return res;}
};

法2思路:利用set去重,然后对于set中的每个字符串,删除set中与其后缀重复的字符串。

class Solution {
public:int minimumLengthEncoding(vector<string>& words) {unordered_set<string>myset(words.begin(), words.end());//利用迭代器构造set对象(自动去重)for (const string& s : myset){for (int i = 1; i < s.size(); i++){myset.erase(s.substr(i));}}int len = 0;for (auto it = myset.begin(); it != myset.end(); it++){len += (*it).size() + 1;}return len;}
};
string s = "abcde";
cout << s.substr(1);//返回的是string类的对象,结果为bcde

这篇关于200330题(820.单词的压缩编码(字典树))的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

POJ2001字典树

给出n个单词,求出每个单词的非公共前缀,如果没有,则输出自己。 import java.io.BufferedReader;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWriter;import java.io.UnsupportedEncodingException;

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

form表单提交编码的问题

浏览器在form提交后,会生成一个HTTP的头部信息"content-type",标准规定其形式为Content-type: application/x-www-form-urlencoded; charset=UTF-8        那么我们如果需要修改编码,不使用默认的,那么可以如下这样操作修改编码,来满足需求: hmtl代码:   <meta http-equiv="Conte

每日一练7:简写单词(含链接)

1.链接 简写单词_牛客题霸_牛客网 2.题目 3.代码1(错误经验) #include <iostream>#include <string>using namespace std;int main() {string s;string ret;int count = 0;while(cin >> s)for(auto a : s){if(count == 0){if( a <=

4-4.Andorid Camera 之简化编码模板(获取摄像头 ID、选择最优预览尺寸)

一、Camera 简化思路 在 Camera 的开发中,其实我们通常只关注打开相机、图像预览和关闭相机,其他的步骤我们不应该花费太多的精力 为此,应该提供一个工具类,它有处理相机的一些基本工具方法,包括获取摄像头 ID、选择最优预览尺寸以及打印相机参数信息 二、Camera 工具类 CameraIdResult.java public class CameraIdResult {

通用内存快照裁剪压缩库Tailor介绍及源码分析(一)

背景 我们知道内存快照是治理 OOM 问题及其他类型的内存问题的重要数据源,内存快照中保存了进程虚拟机的完整的堆内存数据,很多时候也是调查其他类型异常的重要参考。但是dump出来的堆转储文件.hprof往往很大,以 LargeHeap 应用为例,其 OOM 时的内存快照大小通常在512M左右,要有效的存储和获取都是一个问题。 线下拿到hprof文件相对容易,也可以预防OOM,但覆盖的场景十分有

Python字符编码及应用

字符集概念 字符集就是一套文字符号及其编码的描述。从第一个计算机字符集ASCII开始,为了处理不同的文字,发明过几百种字符集,例如ASCII、USC、GBK、BIG5等,这些不同的字符集从收录到编码都各不相同。在编程中出现比较严重的问题是字符乱码。 几个概念 位:计算机的最小单位二进制中的一位,用二进制的0,1表示。 字节:八位组成一个字节。(位与字节有对应关系) 字符:我们肉眼可见的文字与符号。