Chương 2 Các kiểu dữ liệu cơ bản ppt

11 554 0
Chương 2 Các kiểu dữ liệu cơ bản ppt

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

Thông tin tài liệu

1 Các kiểu dữ liệu bản Các kiểu dữ liệu bản Chương 2 Kiểu tập tin 4 Kiểu mảng và chuỗi 1 Kiểu cấu trúc 2 Kiểu con trỏ 3 Độ phức tạp thuật toán 5 Nội dung N N ộ ộ i dung i dung 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u chu u chu ỗ ỗ i (String) i (String)  Một chuỗi là dãy liên tiếp các ký tự kết thúc bằng ký tự \0 mã ASCII bằng 0 (NULL character)  Trong C chuỗi tối đa 65535 ký tự  Các hàm xử lý chuỗi được đặt trong thư viện string.h của C. C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u chu u chu ỗ ỗ i (String) i (String) Khai báo chuỗi: thể dùng các cách sau  char S[10]; //Khai báo một chuỗi ký tự S chiều dài // tối đa 10 (kể cả kí tự kết thúc)  char S[]="ABC";// Khai báo một chuỗi ký tự S chiều // dài bằng chiều dài của chuỗi "ABC" // và giá trị khởi đầu của S là "ABC"  char *S ="ABC";//Giống cách khai báo trên. C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u chu u chu ỗ ỗ i (String) i (String) M M ộ ộ t s t s ố ố thao t thao t á á c trên chu c trên chu ỗ ỗ i i C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c  So sánh 2 chuỗi: strcmp  Sao chép chuỗi: strcpy  Độ dài chuỗi: strlen  Kiểm tra 1 chuỗi nằm trong chuỗi kia: strstr  Cắt 1 từ ra khỏi 1 chuỗi: strtok  Đổi 1 số ra chuỗi: itoa  Đổi 1 chuỗi ra số: atoi, atof,  Nhập một chuỗi: gets  Xuất một chuỗi: puts C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 2 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u m u m ả ả ng (Array) ng (Array)  Mảng là một tập hợp các biến cùng tên và kiểu dữ liệu, được lưu trữ liên tiếp trong bộ nhớ  Mỗi phần tử được đánh chỉ số (Index), phần tử đầu tiên chỉ số là 0  Trong C, một mảng n chiều thể coi là mảng 1 chiều trong đó mỗi phần tử là 1 mảng n-1 chiều. C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u m u m ả ả ng (Array): ng (Array): Khai b Khai b á á o m o m ả ả ng ng <Kiểu dữ liệu> <Tên biến>[<Số phần tử1>][<Số phần tử2>] ; Ví dụ, ta thể khai báo:  Float a[10]; //khai báo mảng 1 chiều 10 phần tử  int a[100][150];//khai báo mảng 2 chiều  int a[][]={{1, 7, -3, 8, 19},{4, 5, 2, 8, 9},{21, -7, 45, -3, 4}}; C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u h u h ợ ợ p (Union) p (Union)  Union là một kiểu dữ liệu đặc biệt trong C, nó tương tự kiểu struct nhưng các phần tử lại dùng chung một vùng nhớ  Cách thức truy xuất đến các thành phần trong kiểu Union giống như kiểu cấu trúc  Dùng kiểu Union khi cần lưu trữ dữ liệu thay đổi theo trạng thái C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u h u h ợ ợ p (Union): p (Union): Khai b Khai b á á o ki o ki ể ể u union u union typedef union <tên kiểu union> { <KDL> <tên trường>; <KDL> <tên trường>; ……… }[<Name>]; C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c Ví dụ, ta thể định nghĩa kiểu số sau: typedef union tagNumber { int i; long l; }Number; Number N; Khi gán N.l=0xFF09 thì thành phần N.i sẽ nhận giá trị là 9 C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u c u c ấ ấ u tr u tr ú ú c (Structure) c (Structure)  Kiểu cấu trúc (hay kiểu mẫu tin) là một tập hợp các biến khác tên và thể khác nhau về kiểu dữ liệu  Cách thức truy xuất đến các thành phần trong kiểu cấu trúc: Têncấutrúc.Tênthànhphần  Dùng kiểu cấu trúc khi muốn lưu trữ thông tin của các đối tượng phức tạp và đa dạng C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u c u c ấ ấ u tr u tr ú ú c (Structure): c (Structure): Khai b Khai b á á o ki o ki ể ể u c u c ấ ấ u tr u tr ú ú c c typedef struct <tên cấu trúc> { <KDL> <tên trường>; <KDL> <tên trường>; ……… }[<TênKiểucấutrúc>]; C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c Ví dụ, ta thể định nghĩa kiểu cấu trúc ngày tháng như sau: typedef struct { int ngay; int thang; int nam; }Ngaythang; Ngaythang N;//khai báo biến C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u c u c ấ ấ u tr u tr ú ú c (Structure): c (Structure): Truy xu Truy xu ấ ấ t d t d ữ ữ li li ệ ệ u u C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c  Cách thức truy xuất đến các thành phần trong kiểu cấu trúc: Têncấutrúc.Tênthành phần  Để lấy địa chỉ của một thành phần trong cấu trúc, ta dùng toán tử &: &Têncấutrúc.Tênthànhphần Vd: Ngaythang N,M; printf(“Nhập ngày tháng: ”); scanf(“%d/%d/%d”,&N.ngay,&N.thang,&N.nam); M=N;//gán biến cấu trúc N vào biến M C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u c u c ấ ấ u tr u tr ú ú c (Structure): c (Structure): H H à à m v m v à à ki ki ể ể u c u c ấ ấ u tr u tr ú ú c c C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c  Đối của hàm thể là: - Biến mẫu tin: khi đó tham số thực tương ứng là một giá trị mẫu tin - Tham chiếu mẫu tin: khi đó tham số thực tương ứng là một địa chỉ mẫu tin - Con trỏ mẫu tin: khi đó tham số thực là địa chỉ của biến cấu trúc.  Hàm thể trả về: - Giá trị mẫu tin: Ngaythang tênhàm( ) - Con trỏ mẫu tin: Ngaythang *tênhàm( ) C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 4 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer)  Kiểu con trỏ là một kiểu dữ liệu đặc biệt trong C, có kích thước 2 bytes và dùng để chứa địa chỉ của một biến đã được cấp phát bộ nhớ  Khi biến con trỏ chứa địa chỉ của biến A ta nói nó đang trỏ tới biến (vùng nhớ) A  Nếu con trỏ chứa giá trị NULL nghĩa là nó không trỏ đến vùng nhớ nào hết C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer) Khai b Khai b á á o bi o bi ế ế n con tr n con tr ỏ ỏ   Tr Tr ự ự c ti c ti ế ế p p : <tênki : <tênki ể ể ucơs ucơs ở ở > *<tênbi > *<tênbi ế ế ncontr ncontr ỏ ỏ >; >; Vd: int *P,*Q;//khai b Vd: int *P,*Q;//khai b á á o bi o bi ế ế n n   Gi Gi á á n ti n ti ế ế p p : typedef <ki : typedef <ki ể ể ucơs ucơs ở ở T> *<tênki T> *<tênki ể ể ucontr ucontr ỏ ỏ >; >; <tênki <tênki ể ể ucontr ucontr ỏ ỏ > <tênbi > <tênbi ế ế ncontr ncontr ỏ ỏ >; >; Vd: typedef int *intPointer;//khai b Vd: typedef int *intPointer;//khai b á á o ki o ki ể ể u u intPointer P,Q;//khai b intPointer P,Q;//khai b á á o bi o bi ế ế n n C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer) Khai b Khai b á á o bi o bi ế ế n con tr n con tr ỏ ỏ  Con trỏ void: con trỏ được khai báo kiểu void có thể chứa địa chỉ của bất kỳ kiểu nào. Tuy nhiên trước khi sử dụng phải ép về một kiểu cụ thể Vd: int X; float Y; void *P; P=&X; //P trỏ đến X (float*) P=&Y; (float*) P=&Y; //P tr //P tr ỏ ỏ đ đ ế ế n Y n Y (int*) P=&X; (int*) P=&X; //P tr //P tr ỏ ỏ đ đ ế ế n X n X C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer) C C á á c thao t c thao t á á c c  Gán địa chỉ một biến cho con trỏ tênbiếncontrỏ = &tênbiếncầnlấyđịachỉ; tênbiếncontrỏ = NULL; Ví dụ:  Chứa địa chỉ của mảng 1 chiều: int *P , A[10]; > P = A;  Chứa địa chỉ của mảng 2 chiều: float *P, B[3][4]; > P = (float*) B;  Chứa địa chỉ của 1 biến cấu trúc: struct HocSinh *P, hs; > P = &hs; C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 5 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer) C C á á c thao t c thao t á á c c  Truy xuất nội dung 1 biến do biến con trỏ trỏ đến Cú pháp:*tênbiếncontrỏ Lưu ý: toán tử * và & cùng độ ưu tiên Ví dụ: int X, *P; X=10; P=&X; //P trỏ đến X printf(“Giá trị X là: %d”,X); printf(“Giá trị do P trỏ đến: %d”,*P); C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer) C C á á c ph c ph é é p to p to á á n n  So sánh địa chỉ chứa trong hai con trỏ, dùng toán tử == hoặc !=  Khi sử dụng con trỏ trên mảng, ta thể thực hiện các phép toán sau  Cộng địa chỉ con trỏ: pt + i ==>Cộng địa chỉ vùng nhớ lưu trong pt với i*sizeof(T)  Trừ hai con trỏ: pt1-pt2 ==>số phần tử kích thước sizeof(T) giữa 2 địa chỉ. C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer) Con tr Con tr ỏ ỏ v v à à m m ả ả ng 1 chi ng 1 chi ề ề u u  Tên mảng là hằng địa chỉ của phần tử đầu tiên trong mảng, thể thực hiện phép cộng địa chỉ với tên mảng. Khi đó (A+i) tương ứng với &A[i]  Ta cũng thể sử dụng con trỏ trên mảng với các phép toán sau  Lấy địa chỉ phần tử thứ i : &A[i]  Cộng địa chỉ Vd: int i, *p, A[3]={10,20,30}; p=A;// hoặc p=&A[0]; for (i=0;i<3;i++) printf(“A[%d]=%d”,i,*(A+i)); for (i=0;i<3;i++) printf(“A[%d]=%d”,i,*(p+i)); C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer) Con tr Con tr ỏ ỏ v v à à m m ả ả ng 2 chi ng 2 chi ề ề u u  Tên mảng là hằng địa chỉ của phần tử đầu tiên trong mảng, thể thực hiện phép cộng địa chỉ với tên mảng. Khi đó (A+i) tương ứng với &A[i][0] Vd: float A[3][2]; ta A ứng với &A[0][0]; (A+1) ứng với &A[1][0]; (A+2) ứng với &A[2][0]  Ta cũng thể sử dụng con trỏ trên mảng với các phép toán sau  Lấy địa chỉ phần tử A[i][j] : p+i*sốcột+j  Cộng địa chỉ C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 6 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer) Con tr Con tr ỏ ỏ v v à à m m ả ả ng 2 chi ng 2 chi ề ề u u Vd: int i,j,k; float *p, A[3][3]; p=(float*)A;// hoặc p=(float*)&A[0][0]; for (i=0;i<3;i++) //In theo mảng 2 chiều for (j=0;j<3;j++) printf(“A[%d][%d]=%d”,i,j,*(p+i*3+j)); for (k=0;k<3*3;k++) //In theo mảng 1 chiều printf(“A[%d]=%d”,k,*(p+k)); C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer) Con tr Con tr ỏ ỏ v v à à ki ki ể ể u c u c ấ ấ u tr u tr ú ú c c  Lấy địa chỉ của một phần tử trong cấu trúc ta dùng toán tử & Vd :struct Ngay{ int ngay,thang,nam;}X; struct Ngay *p; p=&X; //p trỏ đến cấu trúc X  Để truy xuất giá trị của pt trong cấu trúc ta thể  Cách 1: *(p).ngay, *(p).thang, *(p).nam  Cách 2: pngay, pthang, pnam C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u con tr u con tr ỏ ỏ (Pointer) (Pointer) Con tr Con tr ỏ ỏ h h à à m m  Là con trỏ dùng để chứa địa chỉ của hàm  Khai báo hàm và con trỏ hàm phải trung khớp với nhau về các đối số và kiểu dữ liệu trả về  Trước khi dùng phải gán tên hàm cho con trỏ hàm Vd : int Hoanvi( int *x, int *y); //khai báo hàm int (*p)( int*, int*)=Hoanvi; //khai báo con trỏ hàm int x=2, y=3; Hoanvi(&x, &y); //dùng tên hàm p(&x, &y); //dùng con trỏ hàm C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C á á c c c c ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ch ch í í nh nh 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File)  Ưu điểm của RAM: truy xuất nhanh  Nhược điểm của RAM: kích thước hạn chế, không lưu trữ thông tin khi mất điện  Giải pháp: lưu trữ trên bộ nhớ ngoài (ổ đĩa)  Ưu: kích thước lớn, lưu trữ lâu dài  Nhược: truy xuất chậm do sử dụng thiết bị khí C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 7 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File)  2 loại tập tin  Tập tin văn bản (Text file)  Tập tin nhị phân (Binary file)  Các bước làm việc với tập tin 1. Khai báo biến tập tin 2. Mở tập tin 3. Truy xuất nội dung tập tin 4. Đóng tập tin  Trong C, các hàm xử lý tập tin trong thư viện stdio.h C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c bư c bư ớ ớ c thao t c thao t á á c trên t c trên t ậ ậ p tin p tin 1. Khai báo biến tập tin: FILE *ContrỏFile;  File được kết thúc bởi ký tự mã 26 (EOF) 2. Mở tập tin: ContrỏFile = fopen (char *têntậptin, char *kiểu); C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i Mở file để đọc ghi. Nếu file cũ thì nối thêm,nếu không thì tạo mới“a+” Mở file để ghi thêm vào cuối file“a” Mở file mới đọc hoặc ghi.“w+” Mở file mới để ghi. Nếu file đã sẽ bị xóa“w” Mở để sửa“r+” Mở để đọc. Nếu không File sẽ báo lỗi“r” Mở tập tin kiểu văn bản“t” Mở tập tin kiểu nhị phân“b” Ý nghiãKiểu 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c bư c bư ớ ớ c thao t c thao t á á c trên t c trên t ậ ậ p tin p tin V V í í d d ụ ụ : : FILE *fp; FILE *fp; fp = fopen( fp = fopen( “ “ C: C: \ \ \ \ DSHS.DBF DSHS.DBF ” ” , , “ “ wb wb ” ” ); ); if ( fp == 0 ) if ( fp == 0 ) { { perror( perror( “ “ Loi Mo File: Loi Mo File: ” ” ); ); exit(1); exit(1); } } C C á á c ki c ki ể ể u d u d ữ ữ li li ệ ệ u c u c ó ó c c ấ ấ u tr u tr ú ú c c C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c bư c bư ớ ớ c thao t c thao t á á c trên t c trên t ậ ậ p tin p tin 3. Truy xuất dữ liệu file văn bản  File văn bản: đặc điểm ký tự xuống hàng gồm CR(13) và LF(10), khi đọc CR + LF  trả về ký tự “\n”, khi ghi ký tự “\n”  CR + LF  Đọc ghi dữ liệu tuần tự  Ghi dữ liệu • int putc ( int ch, FILE *fp); • int fputc (int ch, FILE *fp); • int fputs (const char *Str, FILE *fp); • int fprintf (FILE *fp, const char *dk, các biểu thức); C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 8 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c bư c bư ớ ớ c thao t c thao t á á c trên t c trên t ậ ậ p tin p tin 3. Truy xuất dữ liệu file văn bản  Đọc dữ liệu • int getc (FILE *fp) ; • int fgetc (FILE *fp) ; • char *fgets (char * Str, int n, FILE *fp); • int fscanf (FILE *fp, const char *dk, địa chỉ các biến); C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c bư c bư ớ ớ c thao t c thao t á á c trên t c trên t ậ ậ p tin p tin 3. Truy xuất dữ liệu file nhị phân  File nhị phân: không ký tự xuống dòng, mỗi lần đọc ghi theo một khối byte (Record)  Đọc ghi dữ liệu tại vị trí Record bất kỳ  Ghi các Record vào File: int fwrite(void *ptr, int sizeofItem, int n, FILE *fp);  Đọc các Record trên File: int fread (void *ptr, int sizeofItem, int n, FILE *fp); C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c bư c bư ớ ớ c thao t c thao t á á c trên t c trên t ậ ậ p tin p tin 3. Truy xuất dữ liệu file nhị phân  Kiểm tra cuối file: int feof (FILE *fp);  Vị trí con trỏ byte: long ftell (FILE *fp);  Di chuyển đầu đọc File: void rewind (FILE *fp); int fseek (FILE *fp, long sốbyte, int vịtríxuấtphát);  Đánh dấu vị trí đầu đọc ghi: int fgetpos (FILE *fp, fpos_t *vịtrí); C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c bư c bư ớ ớ c thao t c thao t á á c trên t c trên t ậ ậ p tin p tin 3. Truy xuất dữ liệu file nhị phân  Quay lại vị trí đã đánh dấu: int fsetpos(FILE * fp, fpos_t *vịtrí);  Đổi tên / di chuyển file : int rename (const char *OldFile, const char *NewFile);  Xóa tập tin: int remove (const char * path); C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 9 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c bư c bư ớ ớ c thao t c thao t á á c trên t c trên t ậ ậ p tin p tin 4. Đóng tập tin  int fclose (FILE *fp); Nếu lỗi hàm cho EOF ngược lại cho giá trị 0.  int fcloseall ( ); Nếu lỗi cho EOF nếu không cho số file được đóng. C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c v c v í í d d ụ ụ int main(int n, char * a[]) //n là số đối số trên dòng lệnh kể cả //tên chương trình a[0] { FILE *fp; char c; int sobyte=0; if (n != 2) { puts("Loi cu phap: "); exit(1); } fp = fopen(a[1], "wt"); while (( c = getchar()) != EOF) //hàm getchar() trả về EOF { putc( c, fp); sobyte++; } //khi lỗi hoặc ấn F6 printf("\n\t 1 file copy \t\t %d bytes ", sobyte); fclose(fp); } C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c v c v í í d d ụ ụ int main(int n, char * a[]) { FILE *fp; char st[80]; int sobyte=0; if (n != 2) { puts("Loi cu phap: "); exit(1); } fp = fopen(a[1], "wt"); while ( gets(st)) != NULL) //hàm gets(st) trả về NULL khi lỗi { fputs( st, fp); fputs("\n", fp); //hoặc ấn F6 sobyte+=strlen(st); } printf("\n\t 1 file copy \t\t %d bytes ", sobyte); fclose(fp); } C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Ki Ki ể ể u t u t ậ ậ p tin (File) p tin (File) C C á á c v c v í í d d ụ ụ typedef struct pointtype Polygol[10]; Polygol P; void main(void) { FILE *fp; char c; int n,i; fp = fopen("c:\\dagiac.dat","rt"); fscanf(fp,"%d",&n); printf("%d\n",n); for (i=0; i<n; i++) fscanf(fp,"%d %d",&P[i].x,&P[i].y); fclose(fp); } C C ấ ấ u tr u tr ú ú c lưu tr c lưu tr ữ ữ trên b trên b ộ ộ nh nh ớ ớ ngo ngo à à i i 10 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Th Th ờ ờ i gian th i gian th ự ự c hi c hi ệ ệ n c n c ủ ủ a thu a thu ậ ậ t to t to á á n n   L L à à s s ố ố l l ệ ệ nh c nh c ầ ầ n thi n thi ế ế t m t m à à m m á á y t y t í í nh th nh th ự ự c hi c hi ệ ệ n khi ch n khi ch ạ ạ y y chương tr chương tr ì ì nh s nh s ử ử d d ụ ụ ng thu ng thu ậ ậ t to t to á á n n   Th Th ờ ờ i gian th i gian th ự ự c hi c hi ệ ệ n m n m ộ ộ t chương tr t chương tr ì ì nh l nh l à à m m ộ ộ t h t h à à m m không âm c không âm c ủ ủ a k a k í í ch thư ch thư ớ ớ c d c d ữ ữ li li ệ ệ u v u v à à o, ký hi o, ký hi ệ ệ u T(n), u T(n), T(n) T(n)   0 0   n n   0 0   Thông thư Thông thư ờ ờ ng ch ng ch ỉ ỉ quan tâm đ quan tâm đ ế ế n th n th ờ ờ i gian th i gian th ự ự c hi c hi ệ ệ n n trong trư trong trư ờ ờ ng h ng h ợ ợ p x p x ấ ấ u nh u nh ấ ấ t t Đ Đ á á nh gi nh gi á á đ đ ộ ộ ph ph ứ ứ c t c t ạ ạ p thu p thu ậ ậ t to t to á á n n 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản T T ỷ ỷ l l ệ ệ tăng c tăng c ủ ủ a h a h à à m (Growth Rate) m (Growth Rate)   Cho hai h Cho hai h à à m không âm T m không âm T 1 1 (n) v (n) v à à T T 2 2 (n) (n)   T T 1 1 (n) c (n) c ó ó t t ỷ ỷ l l ệ ệ gia tăng gi gia tăng gi ố ố ng như T ng như T 2 2 (n) n (n) n ế ế u t u t ồ ồ n t n t ạ ạ i c i c á á c h c h ằ ằ ng ng s s ố ố c v c v à à n n 0 0 : T : T 1 1 (n) (n) ≤ ≤ c.T c.T 2 2 (n) v (n) v ớ ớ i m i m ọ ọ i n i n ≥ ≥ 1 1 V V í í d d ụ ụ : T : T ì ì m t m t ỷ ỷ l l ệ ệ gia tăng c gia tăng c ủ ủ a h a h à à m T m T 1 1 (n) =(n+1) (n) =(n+1) 2 2 Ta th Ta th ấ ấ y y T T 1 1 (n) =n (n) =n 2 2 +2n+1 +2n+1 ≤ ≤ n n 2 2 +2n +2n 2 2 +n +n 2 2 =4n =4n 2 2 v v ớ ớ i m i m ọ ọ i n i n ≥ ≥ 1 1   ch ch ọ ọ n c=4, n n c=4, n 0 0 =1 =1 , ta nói T T 1 1 (n) =(n+1) (n) =(n+1) 2 2 c c ó ó t t ỷ ỷ l l ệ ệ tăng như tăng như T T 2 2 (n) =n (n) =n 2 2 Đ Đ á á nh gi nh gi á á đ đ ộ ộ ph ph ứ ứ c t c t ạ ạ p thu p thu ậ ậ t to t to á á n n 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Đ Đ ộ ộ ph ph ứ ứ c t c t ạ ạ p c p c ủ ủ a thu a thu ậ ậ t to t to á á n (Complexity) n (Complexity)   Cho hai h Cho hai h à à m T m T 1 1 (n) v (n) v à à T T 2 2 (n) (n)   T T 1 1 (n) c (n) c ó ó đ đ ộ ộ ph ph ứ ứ c t c t ạ ạ p l p l à à T T 2 2 (n) n (n) n ế ế u t u t ồ ồ n t n t ạ ạ i c i c á á c h c h ằ ằ ng s ng s ố ố c v c v à à n n 0 0 : T : T 1 1 (n) (n) ≤ ≤ c.T c.T 2 2 (n) v (n) v ớ ớ i m i m ọ ọ i n i n ≥ ≥ n n 0 0   Ký hi Ký hi ệ ệ u: T u: T 1 1 (n) = (n) = O( O( T T 2 2 (n) (n) ) ) đ đ ọ ọ c l c l à à “ “ ô c ô c ủ ủ a T a T 2 2 (n) (n) ” ”   Thông thư Thông thư ờ ờ ng T ng T 2 2 (n) l (n) l à à d d ạ ạ ng h ng h à à m đã bi m đã bi ế ế t như t như : log : log 2 2 n, n, n, n, nlog nlog 2 2 n, n n, n 2 2 , n , n 3 3 , 2 , 2 n n , n!, n , n!, n n n Đ Đ á á nh gi nh gi á á đ đ ộ ộ ph ph ứ ứ c t c t ạ ạ p thu p thu ậ ậ t to t to á á n n 3/11/2010 www.lhu.edu.vn Chương 2 Các kiểu dữ liệu bản Đ Đ ộ ộ ph ph ứ ứ c t c t ạ ạ p c p c ủ ủ a thu a thu ậ ậ t to t to á á n (Complexity) n (Complexity) Đ Đ á á nh gi nh gi á á đ đ ộ ộ ph ph ứ ứ c t c t ạ ạ p thu p thu ậ ậ t to t to á á n n O(1) n T(n) [...].. .Chương 2 Các kiểu dữ liệu bản Chương 2 Các kiểu dữ liệu bản Đánh giá độ phức tạp thuật toán giá độ phứ tạ thuậ toá Đánh giá độ phức tạp thuật toán giá độ phứ tạ thuậ toá Cách tính độ phức tạp của thuật toán (Complexity) tí độ phứ tạ củ thuậ toá Qui tắc nhân: tắ nhân: Cho hai đoạn chương trình P1và P2 lồng nhau; T1(n) = O(f(n)), đoạ trì P1và nhau; T2(n) = O(g(n)) thì thời... nhau; T2(n) = O(g(n)) thì thời gian thực hiện của đoạn hai đoạn chương thì thờ thự hiệ củ đoạ đoạ trình đó là T(n) = O(f(n).g(n)) trì đó O(f(n).g(n)) Qui tắc cộng: tắ cộ ng: Cho hai đoạn chương trình P1 và P2 nối tiếp nhau; và đoạ trì và tiế nhau; và T1(n)=O(f(n)), T2(n)=O(g(n)) thì thời gian thực hiện của đoạn hai thì thờ thự hiệ củ đoạ Cách tính độ phức tạp của thuật toán (Complexity) tí độ phứ tạ... i, j, tepm; {1} for (i = 0 ; i . 1 Các kiểu dữ liệu cơ bản Các kiểu dữ liệu cơ bản Chương 2 Kiểu tập tin 4 Kiểu mảng và chuỗi 1 Kiểu cấu trúc 2 Kiểu con trỏ 3 Độ phức. T 1 1 (n) =(n+1) (n) =(n+1) 2 2 Ta th Ta th ấ ấ y y T T 1 1 (n) =n (n) =n 2 2 +2n+1 +2n+1 ≤ ≤ n n 2 2 +2n +2n 2 2 +n +n 2 2 =4n =4n 2 2 v v ớ ớ i m i m ọ ọ i

Ngày đăng: 24/03/2014, 02:21

Từ khóa liên quan

Tài liệu cùng người dùng

Tài liệu liên quan