一個刪除子字符串的程序

一個刪除子字符串的程序,沒有使用C的相關字符串庫函數:

 

  1. #include <stdio.h>
  2. int del_substr(char *str,char const *substr);
  3. int my_strlen(char const *str);
  4. int main(void)
  5. {
  6.     char str[] = "abcdefgh";
  7.     char *substr1 = "efg";
  8.     char *substr2 = "fgr";
  9.     
  10.     printf("%d/t%s/n",del_substr(str,substr1),str);
  11.     printf("%d/t%s/n",del_substr(str,substr2),str);
  12.     
  13.     return 0;    
  14. /**
  15. **  str -- 字符串
  16. **  substr -- 子字符串 
  17. **  若成功找到子字符串並刪除之,返回1,若沒找到則返回0  
  18. **/
  19. int del_substr(char *str,char const *substr)
  20. {
  21.     int i = 0;
  22.     char *temp_str = str;
  23.     char const *temp_substr = substr;
  24.     int sub_len = my_strlen(substr);
  25.     
  26.     while(1)
  27.     {
  28.          if(*temp_str == *temp_substr)
  29.          {
  30.              temp_substr++;
  31.              if(*temp_substr == '/0')
  32.              {
  33.                    break;         
  34.              }
  35.          }
  36.          else
  37.          {
  38.               temp_substr = substr;          
  39.          }
  40.          
  41.          if(*temp_str == '/0')
  42.          {
  43.              return 0;
  44.          }
  45.          
  46.          temp_str++;                  
  47.     }
  48.     
  49.     char *preDel = temp_str - (sub_len - 1);
  50.     
  51.     while(*(preDel + (i+sub_len)) != '/0')
  52.     {
  53.         *(preDel + i) = *(preDel + (i+sub_len));
  54.         i++;
  55.     }
  56.     
  57.     *(preDel + i) = '/0';
  58.     
  59.     return 1;
  60.        
  61. }
  62.       
  63. int my_strlen(char const *str)
  64. {
  65.     int len = 0;
  66.     
  67.     while( *str++ != '/0')
  68.     {
  69.         len++;
  70.     }
  71.     
  72.     return len;
  73. }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章