NMLT_C17_ChuoiKyTu
Chia sẻ bởi Trần Tuấn Vũ |
Ngày 19/03/2024 |
13
Chia sẻ tài liệu: NMLT_C17_ChuoiKyTu thuộc Công nghệ thông tin
Nội dung tài liệu:
NHẬP MÔN LẬP TRÌNH
CHUỖI KÝ TỰ
Nội dung
Chuỗi ký tự
Khái niệm
Khái niệm
Kiểu char chỉ chứa được một ký tự. Để lưu trữ một chuỗi (nhiều ký tự) ta sử dụng mảng (một chiều) các ký tự.
Chuỗi ký tự kết thúc bằng ký tự ‘ ’ (null)
Độ dài chuỗi = kích thước mảng – 1
Ví dụ
Chuỗi ký tự
char hoten[30]; // Dài 29 ký tự
char ngaysinh[9]; // Dài 8 ký tự
Khởi tạo
Khởi tạo như mảng thông thường
Độ dài cụ thể
Tự xác định độ dài
Chuỗi ký tự
char s[10] = {‘T’, ‘H’, ‘C’, ‘S’, ‘ ’, ‘A’, ‘ ’};
char s[10] = “THCS A”; // Tự động thêm ‘ ’
char s[] = {‘T’, ‘H’, ‘C’, ‘S’, ‘ ’, ‘A’, ‘ ’};
char s[] = “THCS A”; // Tự động thêm ‘ ’
‘T’
‘H’
‘C’
‘S’
‘ ’
‘A’
0
1
2
3
4
5
6
7
8
9
‘T’
‘H’
‘C’
‘S’
‘ ’
‘A’
0
1
2
3
4
5
‘ ’
‘ ’
6
Xuất chuỗi
Sử dụng hàm printf với đặc tả “%s”
Sử dụng hàm puts
Chuỗi ký tự
char monhoc[50] = “Tin hoc co so A”;
printf(“%s”, monhoc); // Không xuống dòng
char monhoc[50] = “Tin hoc co so A”;
puts(monhoc); // Tự động xuống dòng
printf(“%s ”, monhoc);
Tin hoc co so A
Tin hoc co so A
_
_
Nhập chuỗi
Sử dụng hàm scanf với đặc tả “%s”
Chỉ nhận các ký tự từ bàn phím đến khi gặp ký tự khoảng trắng hoặc ký tự xuống dòng.
Chuỗi nhận được không bao gồm ký tự khoảng trắng và xuống dòng.
Chuỗi ký tự
char monhoc[50];
printf(“Nhap mot chuoi: ”);
scanf(“%s”, monhoc);
printf(“Chuoi nhan duoc la: %s”, monhoc);
Nhap mot chuoi: Tin hoc co so A
Chuoi nhan duoc la: Tin
_
Nhập chuỗi
Sử dụng hàm gets
Nhận các ký tự từ bàn phím đến khi gặp ký tự xuống dòng.
Chuỗi nhận được là những gì người dùng nhập (trừ ký tự xuống dòng).
Chuỗi ký tự
char monhoc[50];
printf(“Nhap mot chuoi: ”);
gets(monhoc);
printf(“Chuoi nhan duoc la: %s”, monhoc);
Nhap mot chuoi: Tin hoc co so A
Chuoi nhan duoc la: Tin hoc co so A
_
Một số hàm thao tác trên chuỗi
Thuộc thư viện
strlen
strcpy
strdup
strlwr/strupr
strrev
strcmp/stricmp
strcat
strstr
Chuỗi ký tự
Hàm tính độ dài chuỗi
Chuỗi ký tự
Tính độ dài chuỗi s.
size_t thay cho unsigned (trong) dùng để đo các đại lượng không dấu.
Độ dài chuỗi s (không tính ký tự kết thúc)
char s[] = “Visual C++ 6.0”;
int len = strlen(s); // => 14
Trả về
size_t strlen(const char *s)
Hàm sao chép chuỗi
Chuỗi ký tự
Sao chép chuỗi src sang chuỗi dest, dừng khi ký tự kết thúc chuỗi ‘ ’ vừa được chép.
! dest phải đủ lớn để chứa src
Con trỏ dest.
char s[100];
s = “Visual C++ 6.0”; // sai
strcpy(s, “Visual C++ 6.0”); // đúng
Trả về
char *strcpy(char *dest, const char *src)
Hàm tạo bản sao
Chuỗi ký tự
Tạo bản sao của một chuỗi s cho trước. Hàm sẽ tự tạo vùng nhớ dài strlen(s) + 1 (bytes) để chứa chuỗi s. Phải tự hủy vùng nhớ này khi không sử dụng nữa.
Thành công: trả về con trỏ đến vùng nhớ chứa chuỗi bản sao.
Thất bại: trả về NULL.
char *s;
s = strdup(“Visual C++ 6.0”);
Trả về
char *strdup(const char *s)
Hàm chuyển thành chuỗi thường
Chuỗi ký tự
Chuyển chuỗi s thành chuỗi thường (‘A’ thành ‘a’, ‘B’ thành ‘b’, …, ‘Z’ thành ‘z’)
Con trỏ đến chuỗi s.
char s[] = “Visual C++ 6.0”;
strlwr(s);
puts(s); // visual c++ 6.0
Trả về
char *strlwr(char *s)
Hàm chuyển thành chuỗi IN
Chuỗi ký tự
Chuyển chuỗi s thành chuỗi IN (‘a’ thành ‘A’, ‘b’ thành ‘B’, …, ‘z’ thành ‘Z’)
Con trỏ đến chuỗi s.
char s[] = “Visual C++ 6.0”;
strupr(s);
puts(s); // VISUAL C++ 6.0
Trả về
char *strupr(char *s)
Hàm đảo ngược chuỗi
Chuỗi ký tự
Đảo ngược thứ tự các ký tự trong chuỗi s (trừ ký tự kết thúc chuỗi).
Con trỏ đến chuỗi kết quả.
char s[] = “Visual C++ 6.0”;
strrev(s);
puts(s); // 0.6 ++C lausiV
Trả về
char *strrev(char *s)
Hàm so sánh hai chuỗi
Chuỗi ký tự
So sánh hai chuỗi s1 và s2 (phân biệt hoa thường).
< 0 nếu s1 < s2
== 0 nếu s1 == s2
>0 nếu s1 > s2
char s1[] = “visual C++ 6.0”;
char s2[] = “Visual C++ 6.0”;
int kq = strcmp(s1, s2); // => kq > 0
Trả về
int strcmp(const char *s1, const char *s2)
Hàm so sánh hai chuỗi
Chuỗi ký tự
So sánh hai chuỗi s1 và s2 (không phân biệt hoa thường).
< 0 nếu s1 < s2
== 0 nếu s1 == s2
>0 nếu s1 > s2
char s1[] = “visual c++ 6.0”;
char s2[] = “VISUAL C++ 6.0”;
int kq = stricmp(s1, s2); // => kq == 0
Trả về
int stricmp(const char *s1, const char *s2)
Hàm nối hai chuỗi
Chuỗi ký tự
Nối chuỗi src vào sau chuỗi dest.
! Chuỗi dest phải đủ chứa kết quả
Con trỏ đến chuỗi được nối.
char s1[100] = “Visual C++”;
char s2[] = “6.0”;
strcat(s1, “ ”); // => “Visual C++ ”
strcat(s1, s2); // => “Visual C++ 6.0”
Trả về
char* strcat(char *dest, const char *src)
Hàm tìm chuỗi trong chuỗi
Chuỗi ký tự
Tìm vị trí xuất hiện đầu tiên của s2 trong s1
Thành công: trả về con trỏ đến vị trí xuất hiện đầu tiên của s2 trong s1.
Thất bại: trả về null.
char s1[] = “Visual C++ 6.0”;
char s2[] = “C++”;
if (strstr(s1, s2) != null)
printf(“Tim thay s2 trong s1…”);
Trả về
char* strstr(const char *s1, const char *s2)
Bài tập
Bài 1: Xem thêm một số hàm khác như:
atoi, atol, atof : đổi chuỗi thành số.
itoa, ltoa, ultoa: đổi số thành chuỗi.
strtok
Bài 2: Viết hàm nhận vào một chuỗi và trả về chuỗi tương ứng (giữ nguyên chuỗi đầu vào):
Các ký tự thành ký tự thường (giống strlwr).
Các ký tự thành ký tự hoa (giống strupr).
Các ký tự đầu tiên mỗi từ thành ký tự hoa.
Chuẩn hóa chuỗi (xóa khoảng trắng thừa).
Chuỗi ký tự
Bài tập
Bài 3: Viết hàm nhận vào một chuỗi s và trả về chuỗi tương ứng sau khi xóa các khoảng trắng.
Bài 4: Viết hàm nhận vào một chuỗi s và đếm xem có bao nhiêu từ trong chuỗi đó.
Bài 5: Viết hàm nhận vào một chuỗi s và xuất các từ trên các dòng liên tiếp.
Bài 6: Viết hàm tìm từ có chiều dài lớn nhất và xuất ra màn hình từ đó và độ dài tương ứng.
Bài 7: Viết hàm trích ra n ký tự đầu tiên/cuối cùng/bắt đầu tại vị trí pos của chuỗi s cho trước.
Chuỗi ký tự
CHUỖI KÝ TỰ
Nội dung
Chuỗi ký tự
Khái niệm
Khái niệm
Kiểu char chỉ chứa được một ký tự. Để lưu trữ một chuỗi (nhiều ký tự) ta sử dụng mảng (một chiều) các ký tự.
Chuỗi ký tự kết thúc bằng ký tự ‘ ’ (null)
Độ dài chuỗi = kích thước mảng – 1
Ví dụ
Chuỗi ký tự
char hoten[30]; // Dài 29 ký tự
char ngaysinh[9]; // Dài 8 ký tự
Khởi tạo
Khởi tạo như mảng thông thường
Độ dài cụ thể
Tự xác định độ dài
Chuỗi ký tự
char s[10] = {‘T’, ‘H’, ‘C’, ‘S’, ‘ ’, ‘A’, ‘ ’};
char s[10] = “THCS A”; // Tự động thêm ‘ ’
char s[] = {‘T’, ‘H’, ‘C’, ‘S’, ‘ ’, ‘A’, ‘ ’};
char s[] = “THCS A”; // Tự động thêm ‘ ’
‘T’
‘H’
‘C’
‘S’
‘ ’
‘A’
0
1
2
3
4
5
6
7
8
9
‘T’
‘H’
‘C’
‘S’
‘ ’
‘A’
0
1
2
3
4
5
‘ ’
‘ ’
6
Xuất chuỗi
Sử dụng hàm printf với đặc tả “%s”
Sử dụng hàm puts
Chuỗi ký tự
char monhoc[50] = “Tin hoc co so A”;
printf(“%s”, monhoc); // Không xuống dòng
char monhoc[50] = “Tin hoc co so A”;
puts(monhoc); // Tự động xuống dòng
printf(“%s ”, monhoc);
Tin hoc co so A
Tin hoc co so A
_
_
Nhập chuỗi
Sử dụng hàm scanf với đặc tả “%s”
Chỉ nhận các ký tự từ bàn phím đến khi gặp ký tự khoảng trắng hoặc ký tự xuống dòng.
Chuỗi nhận được không bao gồm ký tự khoảng trắng và xuống dòng.
Chuỗi ký tự
char monhoc[50];
printf(“Nhap mot chuoi: ”);
scanf(“%s”, monhoc);
printf(“Chuoi nhan duoc la: %s”, monhoc);
Nhap mot chuoi: Tin hoc co so A
Chuoi nhan duoc la: Tin
_
Nhập chuỗi
Sử dụng hàm gets
Nhận các ký tự từ bàn phím đến khi gặp ký tự xuống dòng.
Chuỗi nhận được là những gì người dùng nhập (trừ ký tự xuống dòng).
Chuỗi ký tự
char monhoc[50];
printf(“Nhap mot chuoi: ”);
gets(monhoc);
printf(“Chuoi nhan duoc la: %s”, monhoc);
Nhap mot chuoi: Tin hoc co so A
Chuoi nhan duoc la: Tin hoc co so A
_
Một số hàm thao tác trên chuỗi
Thuộc thư viện
strlen
strcpy
strdup
strlwr/strupr
strrev
strcmp/stricmp
strcat
strstr
Chuỗi ký tự
Hàm tính độ dài chuỗi
Chuỗi ký tự
Tính độ dài chuỗi s.
size_t thay cho unsigned (trong
Độ dài chuỗi s (không tính ký tự kết thúc)
char s[] = “Visual C++ 6.0”;
int len = strlen(s); // => 14
Trả về
size_t strlen(const char *s)
Hàm sao chép chuỗi
Chuỗi ký tự
Sao chép chuỗi src sang chuỗi dest, dừng khi ký tự kết thúc chuỗi ‘ ’ vừa được chép.
! dest phải đủ lớn để chứa src
Con trỏ dest.
char s[100];
s = “Visual C++ 6.0”; // sai
strcpy(s, “Visual C++ 6.0”); // đúng
Trả về
char *strcpy(char *dest, const char *src)
Hàm tạo bản sao
Chuỗi ký tự
Tạo bản sao của một chuỗi s cho trước. Hàm sẽ tự tạo vùng nhớ dài strlen(s) + 1 (bytes) để chứa chuỗi s. Phải tự hủy vùng nhớ này khi không sử dụng nữa.
Thành công: trả về con trỏ đến vùng nhớ chứa chuỗi bản sao.
Thất bại: trả về NULL.
char *s;
s = strdup(“Visual C++ 6.0”);
Trả về
char *strdup(const char *s)
Hàm chuyển thành chuỗi thường
Chuỗi ký tự
Chuyển chuỗi s thành chuỗi thường (‘A’ thành ‘a’, ‘B’ thành ‘b’, …, ‘Z’ thành ‘z’)
Con trỏ đến chuỗi s.
char s[] = “Visual C++ 6.0”;
strlwr(s);
puts(s); // visual c++ 6.0
Trả về
char *strlwr(char *s)
Hàm chuyển thành chuỗi IN
Chuỗi ký tự
Chuyển chuỗi s thành chuỗi IN (‘a’ thành ‘A’, ‘b’ thành ‘B’, …, ‘z’ thành ‘Z’)
Con trỏ đến chuỗi s.
char s[] = “Visual C++ 6.0”;
strupr(s);
puts(s); // VISUAL C++ 6.0
Trả về
char *strupr(char *s)
Hàm đảo ngược chuỗi
Chuỗi ký tự
Đảo ngược thứ tự các ký tự trong chuỗi s (trừ ký tự kết thúc chuỗi).
Con trỏ đến chuỗi kết quả.
char s[] = “Visual C++ 6.0”;
strrev(s);
puts(s); // 0.6 ++C lausiV
Trả về
char *strrev(char *s)
Hàm so sánh hai chuỗi
Chuỗi ký tự
So sánh hai chuỗi s1 và s2 (phân biệt hoa thường).
< 0 nếu s1 < s2
== 0 nếu s1 == s2
>0 nếu s1 > s2
char s1[] = “visual C++ 6.0”;
char s2[] = “Visual C++ 6.0”;
int kq = strcmp(s1, s2); // => kq > 0
Trả về
int strcmp(const char *s1, const char *s2)
Hàm so sánh hai chuỗi
Chuỗi ký tự
So sánh hai chuỗi s1 và s2 (không phân biệt hoa thường).
< 0 nếu s1 < s2
== 0 nếu s1 == s2
>0 nếu s1 > s2
char s1[] = “visual c++ 6.0”;
char s2[] = “VISUAL C++ 6.0”;
int kq = stricmp(s1, s2); // => kq == 0
Trả về
int stricmp(const char *s1, const char *s2)
Hàm nối hai chuỗi
Chuỗi ký tự
Nối chuỗi src vào sau chuỗi dest.
! Chuỗi dest phải đủ chứa kết quả
Con trỏ đến chuỗi được nối.
char s1[100] = “Visual C++”;
char s2[] = “6.0”;
strcat(s1, “ ”); // => “Visual C++ ”
strcat(s1, s2); // => “Visual C++ 6.0”
Trả về
char* strcat(char *dest, const char *src)
Hàm tìm chuỗi trong chuỗi
Chuỗi ký tự
Tìm vị trí xuất hiện đầu tiên của s2 trong s1
Thành công: trả về con trỏ đến vị trí xuất hiện đầu tiên của s2 trong s1.
Thất bại: trả về null.
char s1[] = “Visual C++ 6.0”;
char s2[] = “C++”;
if (strstr(s1, s2) != null)
printf(“Tim thay s2 trong s1…”);
Trả về
char* strstr(const char *s1, const char *s2)
Bài tập
Bài 1: Xem thêm một số hàm khác như:
atoi, atol, atof : đổi chuỗi thành số.
itoa, ltoa, ultoa: đổi số thành chuỗi.
strtok
Bài 2: Viết hàm nhận vào một chuỗi và trả về chuỗi tương ứng (giữ nguyên chuỗi đầu vào):
Các ký tự thành ký tự thường (giống strlwr).
Các ký tự thành ký tự hoa (giống strupr).
Các ký tự đầu tiên mỗi từ thành ký tự hoa.
Chuẩn hóa chuỗi (xóa khoảng trắng thừa).
Chuỗi ký tự
Bài tập
Bài 3: Viết hàm nhận vào một chuỗi s và trả về chuỗi tương ứng sau khi xóa các khoảng trắng.
Bài 4: Viết hàm nhận vào một chuỗi s và đếm xem có bao nhiêu từ trong chuỗi đó.
Bài 5: Viết hàm nhận vào một chuỗi s và xuất các từ trên các dòng liên tiếp.
Bài 6: Viết hàm tìm từ có chiều dài lớn nhất và xuất ra màn hình từ đó và độ dài tương ứng.
Bài 7: Viết hàm trích ra n ký tự đầu tiên/cuối cùng/bắt đầu tại vị trí pos của chuỗi s cho trước.
Chuỗi ký tự
* Một số tài liệu cũ có thể bị lỗi font khi hiển thị do dùng bộ mã không phải Unikey ...
Người chia sẻ: Trần Tuấn Vũ
Dung lượng: |
Lượt tài: 1
Loại file:
Nguồn : Chưa rõ
(Tài liệu chưa được thẩm định)