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

C语言朴素算法

#include <stdio.h>
#include <string.h>// 朴素算法,用于字符串匹配
void naiveMatch(char* text, char* pattern) {int textLength = strlen(text);              // 计算文本串长度int patternLength = strlen(pattern);        // 计算模式串长度for (int i = 0; i <= textLength - patternLength; i++) {    // 外层循环控制文本串的起始位置int j;for (j = 0; j < patternLength; j++) {     // 内层循环用于比较文本串和模式串的字符if (text[i + j] != pattern[j]) {      // 如果任何字符不匹配,则内层循环中断break;}}if (j == patternLength) {                 // 如果内层循环成功执行完毕,则找到匹配printf("在位置 %d 处找到匹配\n", i);}}
}int main() {char text[] = "ABABDABACDABABCABAB";char pattern[] = "ABABCABAB";naiveMatch(text, pattern);       // 使用朴素算法进行字符串匹配return 0;
}

朴素算法是一种最简单直观的字符串匹配算法,其时间复杂度为O(m*n),其中m为模式串的长度,n为文本串的长度。在最坏情况下,朴素算法需要进行大量的不必要比较,效率较低。

在上述代码中,我们使用了两个指针ij分别表示文本串和模式串的索引,通过嵌套循环进行匹配的过程。外层循环控制文本串的起始位置,内层循环用于比较文本串和模式串的字符。如果任何字符不匹配,则内层循环中断,并将文本串的指针向后移动一位,重新开始下一轮匹配。如果内层循环成功执行完毕,即完整匹配了模式串中的所有字符,则说明在文本串中找到了匹配,并打印匹配的位置。外层循环继续,直到遍历完整个文本串。

http://www.lryc.cn/news/271937.html

相关文章:

  • 【力扣题解】P501-二叉搜索树中的众数-Java题解
  • Wnmp本地部署结合内网穿透实现任意浏览器远程访问本地服务
  • 深信服AF防火墙配置SSL VPN
  • 在Spring Cloud中使用Gateway 网关
  • 【Python】配置环境变量
  • 使用.Net nanoFramework 驱动ESP32的OLED显示屏
  • 0基础学习VR全景平台篇第134篇:720VR全景,云台调整节点
  • 扫地机器人地图与用户终端的同步
  • 使用机器学习进行语法错误检测/纠正
  • 从0到1快速入门ETLCloud
  • QT上位机开发(会员管理软件)
  • 线性代数笔记3 1.1
  • 2023年12月编程语言排行榜
  • Redis VS Memcached:选择哪个更适合您的应用?
  • 【HarmonyOS开发】共享包HAR和HSP的创建和使用以及三方库的发布
  • 安装 Node.js、npm
  • 解决报错:找不到显卡
  • 如何使用Node.js快速创建本地HTTP服务器并实现公网访问服务端
  • 【社交网络分析】课程考试复盘 + 相关资料补充
  • 算法——队列+宽搜(BFS)
  • 前端八股文(CSS篇)二
  • 系统架构设计师笔记
  • Livox-Mid-360 固态激光雷达ROS格式数据分析
  • 如何恢复 iPhone 上永久删除的照片?
  • 基于单片机的公交车站自动报站器设计与实现
  • python之Selenium WebDriver安装与使用
  • 基于Java+Vue+uniapp微信小程序国产动漫论坛系统设计和实现
  • 奇因子之和(C语言)
  • 简单FTP客户端软件开发——VMware安装Linux虚拟机(命令行版)
  • ArkTS开发实践