(Good topic)单词的压缩编码(leetcode3.28每日打卡)
输出: 10
说明: S = "time#bell#" , indexes = [0, 2, 5] 。
1 <= words.length <= 2000
1 <= words[i].length <= 7
每个单词都是小写字母 。
1 #include<stdio.h>
2 #include<string.h>
3 #include<stdlib.h>
4
5 int Cmp(const void* a, const void* b)
6 {
7 char* s1 = *(char**)a;
8 char* s2 = *(char**)b;
9
10 return strcmp(s1, s2);
11 }
12
13 int minimumLengthEncoding(char** words, int wordsSize)
14 {
15 if (words == NULL || wordsSize == 0)
16 {
17 return 0;
18 }
19 int i, j,res = 0;
20 int totalLen = 0;
21 int* size = (int*)calloc(wordsSize, sizeof(int));
22 char t[9] = { 0 };
23
24 for (i = 0; i < wordsSize; i++) //每个字符串逆序
25 {
26 int len = strlen(words[i]);
27 for (j = 0; j < len / 2; j++)
28 {
29 char t = words[i][j];
30 words[i][j] = words[i][len-j-1];
31 words[i][len-j-1] = t;
32 }
33 }
34 qsort(words, wordsSize, sizeof(char*), Cmp); //字符串字典序排序
35 /*for (i = 0; i < wordsSize-1; i++) //冒泡排序
36 {
37 for (j = 0; j < wordsSize - 1 - i; j++)
38 {
39 if (strcmp(words[j], words[j + 1]) > 0)
40 {
41 strcpy(t, words[j]);
42 strcpy(words[j], words[j + 1]);
43 strcpy(words[j + 1], t);
44 }
45 }
46 }*/
47
48 for (i = 0; i < wordsSize; i++) //总长度,并记录每个串个长度
49 {
50 size[i] = strlen(words[i]);
51 totalLen += size[i];
52 }
53 totalLen += wordsSize; //加所有的'#'
54
55 for (i = 0; i < wordsSize - 1; i++)
56 {
57 if (strncmp(words[i], words[i + 1], size[i]) == 0)
58 {
59 totalLen -= (size[i] + 1);
60 }
61 }
62 free(size);
63 return totalLen;
64 }
65
66 int main(void)
67 {
68 char** s;
69 int num;
70 s = (char **)malloc(sizeof(char*) * 6);
71 for (int i = 0; i < 6; i++)
72 {
73 s[i] = (char *)malloc(sizeof(char) * 10);
74 }
75 strcpy(s[0], "time");
76 strcpy(s[1], "lime");
77 strcpy(s[2], "hell");
78 strcpy(s[3], "sometime");
79 strcpy(s[4], "shell");
80 strcpy(s[5], "me");
81
82 num = minimumLengthEncoding(s, 6);
83 printf("%d", num);
84 return 0;
85 }
(Good topic)单词的压缩编码(leetcode3.28每日打卡)的更多相关文章
- Java实现 LeetCode 820 单词的压缩编码(暴力)
820. 单词的压缩编码 给定一个单词列表,我们将这个列表编码成一个索引字符串 S 与一个索引列表 A. 例如,如果这个列表是 ["time", "me", & ...
- Java实现 LeetCode 820 单词的压缩编码(字典树)
820. 单词的压缩编码 给定一个单词列表,我们将这个列表编码成一个索引字符串 S 与一个索引列表 A. 例如,如果这个列表是 ["time", "me", & ...
- leetcode之820. 单词的压缩编码 | python极简实现字典树
题目 给定一个单词列表,我们将这个列表编码成一个索引字符串 S 与一个索引列表 A. 例如,如果这个列表是 ["time", "me", "bell& ...
- 2018/1/28 每日一学 单源最短路的SPFA算法以及其他三大最短路算法比较总结
刚刚AC的pj普及组第四题就是一种单源最短路. 我们知道当一个图存在负权边时像Dijkstra等算法便无法实现: 而Bellman-Ford算法的复杂度又过高O(V*E),SPFA算法便派上用场了. ...
- [Swift]LeetCode820. 单词的压缩编码 | Short Encoding of Words
Given a list of words, we may encode it by writing a reference string S and a list of indexes A. For ...
- python set() leetcode 签到820. 单词的压缩编码
题目 给定一个单词列表,我们将这个列表编码成一个索引字符串 S 与一个索引列表 A. 例如,如果这个列表是 ["time", "me", "bell& ...
- 【LeetCode】820. 单词的压缩编码 Short Encoding of Words(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 题目地址:https://leetcode-cn.com/problems/short- ...
- 2018/03/28 每日一个Linux命令 之 mkdir/rmdir
用于建立空文件夹和删除文件夹 -- 两命令重要参数 -p 递归建立/删除 -- 例如 mkdir -p demo1/demo2/demo3 建立demo3空文件夹,如果demo1/demo2没建立也建 ...
- P1664 每日打卡心情好
题目背景 在洛谷中,打卡不只是一个简单的鼠标点击动作,通过每天在洛谷打卡,可以清晰地记录下自己在洛谷学习的足迹.通过每天打卡,来不断地暗示自己:我又在洛谷学习了一天,进而帮助自己培养恒心.耐心.细心. ...
- (leetcode每日打卡)秋叶收藏集【动态规划】
LCP 19.秋叶收藏集 题目链接 算法 动态规划 时间复杂度O(n) 1.题目要求最终形成[红.黄.红]三部分,每部分数量可以不相等,问最终调整操作数量最小是多少.这道题一开始考虑暴力去做,枚举两个 ...
随机推荐
- 避坑 | OI排雷新生态
可持久化线段树 query 的时候两结点的 sz 相减的时候一定是左儿子相减. 可持久化线段树建新点要将原来的不更改的节点连接上. 动态规划也可以倒着考虑. P3957的单调队列是先加入后删除,否则加 ...
- webpack是如何处理css/less资源的呢
上一篇文章 体验了webpack的打包过程,其中js文件不需要我们手动配置就可以成功解析,可其它类型的文件,比如css.less呢? css-loader 首先,创建一个空文件夹,通过 npm ini ...
- 原来ES7~12分别增加了这些属性呀
ES6也称为ES2015,于2015年发布,此后每年都有新增一些属性,分别命名为ES7~12,发布的年份分别对应2016年到2021年 ES7 includes方法 数组中新增了includes方法, ...
- 推荐一个高效解压缩工具 - XZ
前情提要:前段时间搞某较大型项目的性能测试,使用的是Oracle数据库.压测阶段搞的业务基础数据和压测数据耗时耗力,想把数据导出,后续有类似项目,可以导入复用. 遇到问题:通过数据泵方式导出的数据库文 ...
- 前瞻|Java 21 新特性 String Templates(字符串模版)
在日常写Java的时候,对于字符串的操作是非常普遍的,其中最常见的就是对字符串的组织.也因为这个操作非常普遍,所以诞生了很多方案,总下来大概有这么几种: 使用+拼接 使用StringBuffer和Sp ...
- 《Python魔法大冒险》010 魔法宝箱:列表与元组的探险
城堡的大门 随着小鱼和魔法师的深入,他们来到了一个古老的废弃城堡.城堡的大门上挂着一个巨大的锁,而锁的旁边有一排小抽屉,每个抽屉里都有一个物品. 魔法师对小鱼说:"这是一个古老的魔法宝箱,小 ...
- 推荐vue脚手架工具 vue-cli
安装vue-cli之前,需要先装好vue 和 webpack npm install -g vue //全局安装vue npm install -g webpack //全局安装webpack npm ...
- 位图(bitmap)原理以及实现
大家好,我是蓝胖子,我一直相信编程是一门实践性的技术,其中算法也不例外,初学者可能往往对它可望而不可及,觉得很难,学了又忘,忘其实是由于没有真正搞懂算法的应用场景,所以我准备出一个系列,囊括我们在日常 ...
- Vitess全局唯一ID生成的实现方案
为了标识一段数据,通常我们会为其指定一个唯一id,比如利用MySQL数据库中的自增主键. 但是当数据量非常大时,仅靠数据库的自增主键是远远不够的,并且对于分布式数据库只依赖MySQL的自增id无法满足 ...
- 11g GI监听测试增加其他本地端口
11.2 GI中监听器的地址和端口信息被移到了 endpoints_listener.ora中. 使用 endpoints_listener.ora的情况下不应使用lsnrctl管理LISTENER, ...