Tìm kiếm chuỗi trong C



Bài tập C: tìm kiếm chuỗi con trong một chuỗi

Yêu cầu bài tập là tìm kiếm một chuỗi con trong một chuỗi và đếm xem chuỗi con đó xuất hiện bao nhiêu lần.

Để giải bài tập C này, chúng ta cần sử dụng các vòng lặp cũng như cần nhớ kiểm tra điều kiện giá trị null (ký tự '\0').

Chương trình C

Dưới đây là chương trình C để giải bài tập tìm kiếm từ hoặc ký tự trong một chuỗi trong C:

#include 
#include int main() {
   char s1[] = "VietJack xin chan thanh cam on ban da theo doi";
   char s2[] = "cam";   int n = 0;
   int m = 0;
   int times = 0;
   int len = strlen(s2);      // bien luu giu do dai cua chuoi can tim kiem   while(s1[n] != '\0') {      if(s1[n] == s2[m]) {     // neu ky tu dau tien la giong nhau         // tiep tuc tim kiem         while(s1[n] == s2[m]  && s1[n] !='\0') {
            n++;
            m++;
         }         // Neu day ky tu nay co do dai bang chuoi tim kiem
         if(m == len && (s1[n] == ' ' || s1[n] == '\0')) {            // Chuc mung ban da tim ra chuoi can tim
            times++;
         }
      }else {            // Neu ky tu dau tien khong giong nhau
         while(s1[n] != ' ') {        //bo qua, tiep tuc tim kiem tu tiep theo
            n++;
            if(s1[n] == '\0')
            break;
         }
      }
		
      n++;
      m=0;  // reset bien dem.
   }   if(times > 0) {
      printf("Chuoi '%s' xuat hien %d lan\n", s2, times);
   }else {
      printf("Chuoi '%s' khong co mat trong cau.\n", s2);
   }   return 0;
}

Biên dịch chương trình C trên sẽ cho kết quả:

Tìm kiếm chuỗi trong C
bai-tap-chuoi-trong-c.jsp