Nội dung chính
Bài tập C: tìm kiếm chuỗi con trong một chuỗi
Đề bài: Viết chương trình 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.
Lời giải
Để 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').
Dưới đây là chương trình C để giải bài tập tìm kiếm chuỗi con trong một chuỗi trong C:
#include <stdio.h> #include <string.h> int main() { char s1[] = "KienThucLapTrinh hoc lap trinh online, hoc c, hoc c++, hoc java, ..."; char s2[] = "hoc"; int n = 0; int m = 0; int times = 0; // bien luu giu do dai cua chuoi can tim kiem int len = strlen(s2); 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 xuat hien trong cau.\n", s2); } return 0; }
Chạy chương trình C trên cho kết quả như sau: