Bài giảng Phương pháp lập trình - Bài 9: Kiểu cấu trúc - Ngô Hữu Dũng
Bạn đang xem 20 trang mẫu của tài liệu "Bài giảng Phương pháp lập trình - Bài 9: Kiểu cấu trúc - Ngô Hữu Dũng", để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên
        Tài liệu đính kèm:
 bai_giang_phuong_phap_lap_trinh_bai_9_kieu_cau_truc_ngo_huu.pdf bai_giang_phuong_phap_lap_trinh_bai_9_kieu_cau_truc_ngo_huu.pdf
Nội dung text: Bài giảng Phương pháp lập trình - Bài 9: Kiểu cấu trúc - Ngô Hữu Dũng
- TRƯỜNG ĐẠI HỌC CÔNG NGHIỆP THÀNH PHỐ HỒ CHÍ MINH Phương pháp lập trình Kiểu cấu trúc TS. Ngô Hữu Dũng
- Đặt vấn đề  Thông tin 1 SV  MSSV : kiểu chuỗi  Tên SV : kiểu chuỗi  NTNS : kiểu chuỗi  Phái : ký tự  Điểm Toán, Lý, Hóa : số thực  Yêu cầu  Lưu thông tin n SV?  Truyền thông tin n SV vào hàm? Phương pháp lập trình - Kiểu cấu trúc
- Đặt vấn đề  Khai báo các biến để lưu trữ 1 SV  char mssv[7]; // “0012078”  char hoten[30]; // “Nguyen Van A”  char ntns[8]; // “29/12/82”  char phai; // ‘y’  Nam, ‘n’  Nữ  float toan, ly, hoa; // 8.5 9.0 10.0  Truyền thông tin 1 SV cho hàm  void xuat(char mssv[], char hoten[], char ntns[], char phai, float toan, float ly, float hoa); Phương pháp lập trình - Kiểu cấu trúc
- Đặt vấn đề  Nhận xét  Đặt tên biến khó khăn và khó quản lý  Truyền tham số cho hàm quá nhiều  Tìm kiếm, sắp xếp, sao chép, khó khăn  Tốn nhiều bộ nhớ   Ý tưởng  Gom những thông tin của cùng 1 SV thành một kiểu dữ liệu mới => Kiểu struct Phương pháp lập trình - Kiểu cấu trúc
- Khai báo kiểu cấu trúc  Cú pháp 1. struct 2. { 3. ; 4. 5. ; 6. };  Ví dụ 1. struct DIEM 2. { 3. int x; 4. int y; 5. }; Phương pháp lập trình - Kiểu cấu trúc
- Khai báo biến cấu trúc  Cú pháp tường minh 1. struct 2. { 3. ; 4. 5. ; 6. } , ;  Ví dụ 1. struct DIEM 2. { 3. int x; 4. int y; 5. } diem1, diem2; Phương pháp lập trình - Kiểu cấu trúc
- Khai báo biến cấu trúc  Cú pháp không tường minh 1. struct 2. { 3. ; 4. 5. ; 6. }; 7. struct ;  Ví dụ 1. struct DIEM 2. { 3. int x; 4. int y; 5. }; 6. struct DIEM diem1, diem2;// C++ có thể bỏ struct Phương pháp lập trình - Kiểu cấu trúc
- Sử dụng typedef  Cú pháp 1. typedef struct 2. { 3. ; 4. 5. ; 6. } ; 7. ;  Ví dụ 1. typedef struct 2. { 3. int x; 4. int y; 5. } DIEM; 6. struct DIEM diem1, diem2; Phương pháp lập trình - Kiểu cấu trúc
- Khởi tạo cho biến cấu trúc  Cú pháp tường minh 1. struct 2. { 3. ; 4. 5. ; 6. } = { , , };  Ví dụ 1. struct DIEM 2. { 3. int x; 4. int y; 5. } diem1 = {2912, 1706}, diem2; Phương pháp lập trình - Kiểu cấu trúc
- Truy xuất dữ liệu kiểu cấu trúc  Đặc điểm  Không thể truy xuất trực tiếp  Thông qua toán tử thành phần cấu trúc . hay còn gọi là toán tử chấm (dot operation)  Ví dụ . 1. struct DIEM 2. { 3. int x; 4. int y; 5. } diem1; 6. printf(“x = %d, y = %d”, diem1.x, diem1.y); Phương pháp lập trình - Kiểu cấu trúc
- Gán dữ liệu kiểu cấu trúc  Có 2 cách = ; . = ;  Ví dụ 1. struct DIEM 2. { 3. int x, y; 4. } diem1 = {2912, 1706}, diem2; 5. 6. diem2 = diem1; 7. diem2.x = diem1.x; 8. diem2.y = diem1.y * 2; Phương pháp lập trình - Kiểu cấu trúc
- Cấu trúc phức tạp  Thành phần của cấu trúc là cấu trúc khác 1. struct DIEM 2. { 3. int x; 4. int y; 5. }; 6. struct HINHCHUNHAT 7. { 8. struct DIEM traitren; 9. struct DIEM phaiduoi; 10.} hcn1; 11. 12.hcn1.traitren.x = 2912; 13.hcn1.traitren.y = 1706; Phương pháp lập trình - Kiểu cấu trúc
- Cấu trúc phức tạp  Thành phần của cấu trúc là mảng 1. struct SINHVIEN 2. { 3. char hoten[30]; 4. float toan, ly, hoa; 5. } sv1; 6. 7. strcpy(sv1.hoten, “Nguyen Van A”); 8. sv1.toan = 10; 9. sv1.ly = 6.5; 10.sv1.hoa = 9; Phương pháp lập trình - Kiểu cấu trúc
- Cấu trúc phức tạp  Cấu trúc đệ quy (tự trỏ) 1. struct PERSON 2. { 3. char hoten[30]; 4. struct PERSON *father, *mother; 5. }; 6. struct NODE 7. { 8. int value; 9. struct NODE *pNext; 10.}; Phương pháp lập trình - Kiểu cấu trúc
- Cấu trúc phức tạp  Thành phần của cấu trúc có kích thước theo bit 1. struct bit_fields 2. { 3. int bit_0 : 1; 4. int bit_1_to_4 : 4; 5. int bit_5 : 1; 6. int bit_6_to_15 : 10; 7. }; 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 Phương pháp lập trình - Kiểu cấu trúc
- Kích thước của struct  Ví dụ 1. struct A 2. { 3. int a; 4. double b; 5. }; 6. sizeof(A) = ??? 1. struct B1 1. struct B2 2. { 2. { 3. int a; 3. int a; 4. int b; 4. double c; 5. double c; 5. int b; 6. }; 6. }; 7. sizeof(B1) = ??? 7. sizeof(B2) = ??? Phương pháp lập trình - Kiểu cấu trúc
- Chỉ thị #pragma pack  Chỉ thị #pragma pack (n)  n = 1, 2, 4, 8, 16 (byte)  Biên lớn nhất của các thành phần trong struct  BC n mặc định là 1  VC++ n mặc định là 8  Project settings Compile Option C/C++ Code Generation Structure Alignment  Canh biên cho 1 cấu trúc #pragma pack(push, 1) struct MYSTRUCT { }; #pragma pack(pop) Phương pháp lập trình - Kiểu cấu trúc
- #pragma pack  Ví dụ: không có #pragma pack (1) struct A { double a; a a a a a a a a int b; int c; b b b b c c c c }; struct B { int b; b b b b đệm 4B double a; a a a a a a a a int c; }; c c c c đệm 4B struct C { int b; b b b b c c c c int c; double a; a a a a a a a a }; Phương pháp lập trình - Kiểu cấu trúc
- Các lưu ý về cấu trúc  Lưu ý  Kiểu cấu trúc được định nghĩa để làm khuôn dạng còn biến cấu trúc được khai báo để sử dụng khuôn dạng đã định nghĩa.  Trong C++, có thể bỏ từ khóa struct khi khai báo biến (hoặc sử dụng typedef)  Khi nhập các biến kiểu số thực trong cấu trúc phải nhập thông qua một biến trung gian. 1. struct DIEM { float x, y;} d1; 2. float temp; scanf(“%f”, &temp); d1.x = temp; Phương pháp lập trình - Kiểu cấu trúc
- Mảng cấu trúc  Mảng cấu trúc  Tương tự như mảng với kiểu dữ liệu cơ sở (char, int, float, ) 1. struct DIEM 2. { 3. int x; 4. int y; 5. }; 6. DIEM mang1[20]; 7. DIEM mang2[10] = {{3, 2}, {4, 4}, {2, 7}}; Phương pháp lập trình - Kiểu cấu trúc
- Truyền cấu trúc cho hàm  Truyền cấu trúc cho hàm  Giống như truyền kiểu dữ liệu cơ sở  Tham trị (không thay đổi sau khi kết thúc hàm)  Tham chiếu  Con trỏ  Ví dụ 1. struct DIEM { 2. int x, y; 3. }; 4. void xuat1(int x, int y) { }; 5. void xuat2(DIEM diem) { }; 6. void xuat3(DIEM &diem) { }; 7. void xuat4(DIEM *diem) { }; Phương pháp lập trình - Kiểu cấu trúc
- Hợp nhất – union  Khái niệm  Được khai báo và sử dụng như cấu trúc  Các thành phần của union có chung địa chỉ đầu (nằm chồng lên nhau trong bộ nhớ)  Khai báo union { ; ; }; Phương pháp lập trình - Kiểu cấu trúc
- So sánh struct và union  Ví dụ 1. struct MYSTRUCT 1. union MYUNION 2. { 2. { 3. char c; 3. char c; 4. int n; 4. int n; 5. } s; 5. } u; 6. s.c = 1; s.n = 2; 6. u.c = 1; u.n = 2; 0 1 2 3 4 0 1 2 3 01 02 00 00 00 0102 00 00 00 c n c n Phương pháp lập trình - Kiểu cấu trúc
- Ví dụ  struct trong union 1. union date_tag 2. { 3. char full_date[9]; 4. struct part_date_tag 5. { 6. char month[2]; 7. char break_value1; 8. char day[2]; 9. char break_value2; 10. char year[2]; 11. }; 12.} date = {“29/12/82”}; Phương pháp lập trình - Kiểu cấu trúc
- Ví dụ  union trong struct 1. struct generic_tag 2. { 3. char type; 4. union share_tag 5. { 6. char c; 7. int i; 8. float f; 9. }; 10.}; Phương pháp lập trình - Kiểu cấu trúc
- Bài tập về cấu trúc 1. Phân số  Khai báo kiểu dữ liệu phân số (PHANSO)  Nhập/Xuất phân số  Rút gọn phân số  Tính tổng, hiệu, tích, thương hai phân số  Kiểm tra phân số tối giản  Quy đồng hai phân số  Kiểm tra phân số âm hay dương  So sánh hai phân số Phương pháp lập trình - Kiểu cấu trúc
- Bài tập về cấu trúc 2. Đơn thức  Khai báo kiểu dữ liệu đơn thức (DONTHUC)  Nhập/Xuất đơn thức  Tính tích, thương hai đơn thức  Tính đạo hàm cấp 1 của đơn thức  Tính giá trị đơn thức tại x = x0 Phương pháp lập trình - Kiểu cấu trúc
- Bài tập về cấu trúc 3. Đa thức  Khai báo kiểu dữ liệu đa thức (DATHUC)  Nhập/Xuất đa thức  Tính tổng, hiệu, tích, thương hai đơn thức  Tính đạo hàm cấp 1 của đơn thức  Tính đạo hàm cấp k của đơn thức  Tính giá trị đơn thức tại x = x0 Phương pháp lập trình - Kiểu cấu trúc
- Bài tập về cấu trúc 4. Điểm trong mặt phẳng Oxy  Khai báo kiểu dữ liệu điểm (DIEM)  Nhập/Xuất tọa độ điểm  Tính khoảng cách giữa hai điểm  Tìm điểm đối xứng qua gốc toạ độ/trục Ox/Oy  Kiểm tra điểm thuộc phần tư nào? 5. Tam giác  Khai báo kiểu dữ lịêu tam giác (TAMGIAC)  Nhập/Xuất tam giác  Tính chu vi, diện tích tam giác Phương pháp lập trình - Kiểu cấu trúc
- Bài tập về cấu trúc 6. Ngày  Khai báo kiểu dữ liệu ngày (NGAY)  Nhập/Xuất ngày (ngày, tháng, năm)  Kiểm tra năm nhuận  Tính số thứ tự ngày trong năm  Tính số thứ tự ngày kể từ ngày 1/1/1  Tìm ngày trước đó, sau đó k ngày  Tính khoảng cách giữa hai ngày  So sánh hai ngày Phương pháp lập trình - Kiểu cấu trúc
- Bài tập về mảng cấu trúc 7. Mảng phân số  Nhập/Xuất n phân số  Rút gọn mọi phân số  Đếm số lượng phân số âm/dương trong mảng  Tìm phân số dương đầu tiên trong mảng  Tìm phân số nhỏ nhất/lớn nhất trong mảng  Sắp xếp mảng tăng dần/giảm dần Phương pháp lập trình - Kiểu cấu trúc
- Bài tập về mảng cấu trúc 8. Mảng điểm  Nhập/Xuất n điểm  Đếm số lượng điểm có hoành độ dương  Đếm số lượng điểm không trùng với các điểm khác trong mảng  Tìm điểm có hoành độ lớn nhất/nhỏ nhất  Tìm điểm gần gốc tọa độ nhất Phương pháp lập trình - Kiểu cấu trúc






