在字符串中查找子字符串的算法

转载 2006年06月09日 14:25:00
 在字符串中查找子字符串的算法

#include <stdio.h>

int strlen(char *str)
{
   int i;

   for ( i = 0; str[i] != '/0'; i++ ); /* 用循环计算长度 */
   return i;
}

/* ---------------------------------------- */
/*  在字符串中找寻子字符串                      */
/* ---------------------------------------- */
int strindex(char *str,char *substr)
{
   int end,i,j;

   end = strlen(str) - strlen(substr);  /* 计算结束位置   */
   if ( end > 0 )                      /* 子字符串小于字符串 */
   {
      for ( i = 0; i <= end; i++ )
         /* 用循环比较 */
         for ( j = i; str[j] == substr[j-i]; j++ )
            if ( substr[j-i+1] == '/0' ) /* 子字符串字结束   */
               return i + 1;           /* 找到了子字符串   */
   }
   return -1;
}

/* ---------------------------------------- */
/*  主程式: 在字符串中找寻子字符串出现位置.     */
/* ---------------------------------------- */
void main()
{
   char string[100];                   /* 字符串阵列宣告   */
   char substring[100];                /* 子字符串阵列宣告 */
   int result;                         /* 找寻结果       */

   printf("请输入字符串 ==> ");
   gets(string);                       /* 读取字符串       */
   printf("请输入要搜索的子字符串 ==> ");
   gets(substring);                    /* 读取子字符串     */
   result = strindex(string,substring);  /* 搜寻子字符串   */
   if ( result > 0 )
      printf("子字符串 %s 位置在 %d/n",substring,result);
   else
      printf("没有找到子字符串 %s/n",substring);
   getchar();
}

数据结构与算法--Boyer-Moore和Rabin-Karp子字符串查找

数据结构与算法--Boyer-Moore和Rabin-Karp子字符串查找 Boyer-Moore字符串查找算法 注意,《算法4》上将这个版本的实现称为Broyer-Moore算法,我看了...

查找子字符串----KMP算法深入剖析

假设主串:a b a b c a b c a c b a b         子串:a b c a c 1、一般匹配算法 逐个字符的比较,匹配过程如下:   第一趟匹配   a b a b ...

子字符串的查找/KMP算法(正在更新)

作者:disappearedgod 文章出处:http://blog.csdn.net/disappearedgod/article/details/23621903 时间:2014-4-16 ...

KMP子字符串查找算法

1. 引言     本KMP原文最初写于2年多前的2011年12月,因当时初次接触KMP,思路混乱导致写也写得混乱。所以一直想找机会重新写下KMP,但苦于一直以来对KMP的理解始终不够,故才迟迟...

KMP算法:查找子字符串

原文地址 :字符串匹配的KMP算法  字符串匹配是计算机的基本任务之一。举例来说,有一个字符串"BBC ABCDAB ABCDABCDABDE",我想知道,里面是否包含另一个字符串"ABCDABD"...

子字符串查找(上):从暴力算法到KMP

子字符串查找(串匹配)很常用,当你在文本编辑器中使用搜索功能定位某个单词,或者在浏览器中输入一个关键字搜索网页,你可能从未意识到此时你正面临的就是子字符串查找问题。你得到了想要的结果,而这背后起作用的...

KMP子字符串查找算法

KMP子字符串查找算法概述算法的基本思想是:当出现不匹配时,就能知晓一部分文本的内容,可以利用这些信息避免将指针回退到所有这些已知的字符串之前。DFA(确定有限状态机)模拟提前判断如何重新查找,而这种...

几个最大子字符串的算法题

  • 2009年02月01日 11:59
  • 5KB
  • 下载

子字符串查找算法_归纳及汇总

字符串的一种基本操作就是子字符串查找:给定一段长度为N的文本和一段长度为M的模式字符串,在文本中找到一个和该模式相符的字符串。 模式-> ABCDE 正文-> SJAHDJKS”ABCDE”...

子字符串查找算法

刚写了几个字符串查找的算法,最朴素的字符串查找,RK算法,KMP算法。Java版实现如下:public class FindSubString { //最朴素的字符串查找 public ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在字符串中查找子字符串的算法
举报原因:
原因补充:

(最多只允许输入30个字)