文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>在字符串中查找子字符串的算法

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

时间:2010-12-09  来源:LaoLiulaoliu

#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();
}


相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载