VietTuts

Tự Học Lập Trình Online

  • Home
  • Java
  • Servlet
  • JSP
  • Struts2
  • Hibernate
  • Spring
  • MyBatis
  • Java WS
  • C
  • C++
  • Python
  • PHP
  • Eclipse
  • VBA
  • Web
    • JavaScript
    • JQUERY
    • JSON
    • AJAX
    • CSS
    • HTML
    • Node.js
    • Angular 7
  • SQL
    • MySQL
    • SQL Server
  • Misc
    • Phần mềm tiện ích
    • Cấu trúc dữ liệu và giải thuật
    • Học lập trình C#
    • Selenium Test
C Cơ Bản String Trong C++ Xử Lý File Trong C++

Bài Tập C++

Danh sách bài tập C++

Bài Tập C++ Kinh Điển

Dãy số Fibonacci trong C++ Check số nguyên tố trong C++ Tính giai thừa trong C++ Chuyển đổi hệ cơ số trong C++

Bài Tập C++ Cơ Bản

Giải phương trình bậc 2 Tìm ước số chung lớn nhất (UCLN) và bội số chung nhỏ nhất (BCNN) Liệt kê tất cả số nguyên tố nhỏ hơn n Liệt kê n số nguyên tố đầu tiên Liệt kê tất cả số nguyên tố có 5 chữ số Phân tích số nguyên Tính tổng của các chữ số của một số nguyên Tìm số thuận nghịch Tìm số Fibonacci nhỏ hơn n là nguyên tố

Bài Tập C++ Nâng Cao

Bài tập quản lý sinh viên trong C/C++

Bài tập C++ - Tìm kiếm chuỗi trong C++


Bài tập C++ - Đảo ngược chuỗi trong C++
Bài tập C++ - Nối chuỗi trong C++

Nội dung chính

  • Bài tập C++: tìm kiếm chuỗi con trong một chuỗi
  • Lời giải

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[] = "VietTuts 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.
   }

   printf("Chuoi ban dau: %s", s1);
   if(times > 0) {
      printf("\nChuoi '%s' xuat hien %d lan\n", s2, times);
   }else {
      printf("\nChuoi '%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:

Tìm kiếm chuỗi trong C++
Bài tập C++ - Đảo ngược chuỗi trong C++
Bài tập C++ - Nối chuỗi trong C++

Recent Updates

Đa luồng trong C++Xử lý ngoại lệ trong C++Nạp chồng toán tử truy cập thành viên lớp (->) trong C++Nạp chồng toán tử subscript [] trong C++Nạp chồng toán tử gọi hàm () trong C++Nạp chồng toán tử gán trong C++Nạp chồng toán tử ++ và -- trong C++Nạp chồng toán tử Input/Output trong C++Nạp chồng toán tử quan hệ trong C++Nạp chồng toán tử nhị phân trong C++Nạp chồng toán tử một ngôi trong C++Nạp chồng toán tử và Nạp chồng hàm trong C++

VietTuts on facebook

Học Lập Trình Online Miễn Phí - VietTuts.Vn

Danh sách bài học

Học java
Học servlet
Học jsp
Học Hibernate
Học Struts2
Học Spring
Học SQL

Câu hỏi phỏng vấn

201 câu hỏi phỏng vấn java
25 câu hỏi phỏng vấn servlet
75 câu hỏi phỏng vấn jsp
52 câu hỏi phỏng vấn Hibernate
70 câu hỏi phỏng vấn Spring
57 câu hỏi phỏng vấn SQL

About VietTuts.Vn

Hệ thống bài học trên VietTuts.Vn bao gồm các bài lý thuyết và thực hành về các công nghệ java và công nghệ web. Các bài lý thuyết trên hệ thống VietTuts.Vn được tham khảo và tổng hợp từ các trang http://javatpoint.com, http://www.tutorialspoint.com, http://docs.oracle.com/en …

Scroll back to top

Copyright © 2016 VietTuts.Vn all rights reserved. | VietTuts.Vn team | Liên hệ | Chính sách - riêng tư | sitemap.html | sitemap_index.xml