网站首页 > 技术文章 正文
以下是C语言实现查找字符串数组最长公共前缀的代码:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
char* longestCommonPrefix(char** strs, int strsSize) {
// 处理空数组情况
if (strsSize == 0) {
char* result = malloc(1);
result[0] = '\0';
return result;
}
// 获取第一个字符串作为基准
char* first = strs[0];
size_t len = strlen(first);
// 为结果分配内存(长度不超过基准字符串)
char* result = malloc(len + 1);
int i;
// 纵向扫描所有字符串
for (i = 0; i < len; i++) {
char current = first[i];
// 检查后续字符串的对应位置
for (int j = 1; j < strsSize; j++) {
/* 关键判断:当出现以下情况时停止扫描
1. 当前字符串长度不足
2. 字符不匹配 */
if (strs[j][i] != current) {
goto end; // 跳出所有循环
}
}
result[i] = current; // 记录当前匹配的字符
}
end:
result[i] = '\0'; // 添加字符串终止符
return result;
}
/* 测试代码 */
int main() {
char* test1[] = {"flower", "flow", "flight"};
char* test2[] = {"dog", "racecar", "car"};
char* test3[] = {"", "abc"};
char* test4[] = {"abc"};
printf("测试1: %s\n", longestCommonPrefix(test1, 3)); // 输出"fl"
printf("测试2: %s\n", longestCommonPrefix(test2, 3)); // 输出""
printf("测试3: %s\n", longestCommonPrefix(test3, 2)); // 输出""
printf("测试4: %s\n", longestCommonPrefix(test4, 1)); // 输出"abc"
// 记得释放内存(演示时省略)
return 0;
}
逐行解析:
- 函数入口处理:
if (strsSize == 0) {
char* result = malloc(1);
result[0] = '\0';
return result;
}
- 处理空数组的特殊情况
- 分配1字节内存存放空字符串
- 基准字符串获取:
char* first = strs[0];
size_t len = strlen(first);
- 以第一个字符串为比较基准
- 获取基准字符串长度用于循环控制
- 内存分配:
char* result = malloc(len + 1);
- 分配足够存储最长可能前缀的内存(基准字符串长度+1)
- +1用于存放字符串终止符'\0'
- 纵向扫描循环:
for (i = 0; i < len; i++) {
char current = first[i];
- 逐个字符检查基准字符串的每个位置
- current存储当前需要匹配的字符
- 内层校验循环:
for (int j = 1; j < strsSize; j++) {
if (strs[j][i] != current) {
goto end;
}
}
- 关键逻辑:检查所有其他字符串的当前位置
- j从1开始跳过基准字符串
- 任一字符串出现长度不足或字符不匹配立即终止
- 字符记录与终止:
result[i] = current; // 记录匹配字符
- 所有字符串当前位置匹配时记录该字符
end:
result[i] = '\0';
- 统一处理字符串终止符
- 自动处理全匹配、提前终止、空字符串等情况
算法特点:
- 时间复杂度:O(S),S为所有字符串字符总数
- 空间复杂度:O(1)(不考虑返回字符串占用的空间)
- 提前终止机制:发现不匹配立即停止扫描
- 内存安全:始终保证返回字符串正确终止
执行结果:
测试1: fl
测试2:
测试3:
测试4: abc
常见问题处理:
- 空数组:直接返回空字符串
- 单元素数组:返回该字符串副本
- 基准字符串为空:立即返回空字符串
- 中间字符串较短:自动终止扫描
- 完全匹配:返回整个基准字符串
注意:调用者需负责释放返回字符串的内存,实际使用时应添加内存释放代码。
- 上一篇: 详解|一文带你了解页面框架层级
- 下一篇: C语言求两个数的最大公约数,最小公倍数
猜你喜欢
- 2025-07-21 C程序设计之:1-1/2+1/3-... + 1/n 的和
- 2025-07-21 C语言__FILE__、__LINE__等预定义跟踪调试
- 2025-07-21 C语言之核心语法(c语言核心技术第2版pdf)
- 2025-07-21 浙江男子为装修700万豪宅,买了套20万家具,收到后心都凉了
- 2025-07-21 C语言while循环要点(c语言的while循环)
- 2025-07-21 C语言-4种运算符(c语言运算符?)
- 2025-07-21 大话C语言:比较运算符(c语言比较语句)
- 2025-07-21 C语言进阶教程:数据结构-树(二叉树、平衡树)的概念与基本操作
- 2025-07-21 C语言实现“简单输出整数”,基础编程由此开始(函数篇第一节)
- 2025-07-21 C 语言技能提升:玩转运算符与表达式,提升自己的逻辑运算掌控力
- 1520℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 623℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 526℃MySQL service启动脚本浅析(r12笔记第59天)
- 492℃启用MySQL查询缓存(mysql8.0查询缓存)
- 491℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 479℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 460℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 458℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- windowsscripthost (69)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)