intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Bài giảng Kỹ thuật lập trình nâng cao: Chương 5 - Trần Minh Thái

Chia sẻ: Y Nhân | Ngày: | Loại File: PDF | Số trang:19

24
lượt xem
3
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

Bài giảng "Kỹ thuật lập trình nâng cao - Chương 5: Kiểu dữ liệu có cấu trúc" cung cấp cho người học các kiến thức: Khái niệm, kiểu dữ liệu có cấu trúc, truy cập các thuộc tính cấu trúc,... Mời các bạn cùng tham khảo nội dung chi tiết.

Chủ đề:
Lưu

Nội dung Text: Bài giảng Kỹ thuật lập trình nâng cao: Chương 5 - Trần Minh Thái

  1. TRẦN MINH THÁI minhthai@itc.edu.vn 1
  2. * Kiểu dữ liệu có cấu trúc thực chất là một kiểu dữ liệu do người dùng định nghĩa bằng cách gom nhóm các kiểu dữ liệu cơ bản có sẵn trong C thành một kiểu dữ liệu phức hợp nhiều thành phần *Khai báo struct tên_struct { khai báo các thuộc tính; }; typedef struct tên_struct TÊNKDL; 2
  3. * *Ví dụ khai báo kiểu dữ liệu lưu thông tin của ngày: struct ttDate { char thu[10]; unsigned char ngay; unsigned char thang; int nam; }; typedef struct ttDate DATE; 3
  4. * *Biến kiểu cấu trúc TÊNKDL tên_biến; tên_biến.tên_thuộc_tính; *Ví dụ DATE x; x.ngay = 5; 4
  5. * *Biến con trỏ kiểu cấu trúc TÊNKDL *tên_biến_con_trỏ; tên_biến_con_trỏ -> tên_thuộc_tính; Ví dụ: DATE *x ; x -> ngay = 5 ; 5
  6. *Khai báo đệ qui struct tên_struct { khai báo các thuộc tính; struct tên_struct *tên_thuộc_tính_đệ_qui; }; 6
  7. *Ví dụ: struct ttNode { int key; struct ttNode *pNext; }; 7
  8. Ví dụ: Viết chương trình nhập vào toạđộ hai điểm độ trong mặt phẳng vàtính tổng hai toạ này //File Khaibao.h #include struct ttDIEM { int x; int y; }; typedef struct ttDIEM DIEM; 8
  9. //File caidat.cpp #include "khaibao.h" void Nhap (DIEM &d) { coutd.y; } 9
  10. void Xuat (DIEM d) { cout
  11. //File main.cpp #include”khaibao.h” void main () { DIEM A , B, AB; //khai bao 3 diem A, B, AB; Nhap (A); Xuat (A); Nhap (B); Xuat (B); cout
  12. * Viết chương trình nhập vào thông tin của một sinh viên gồm: *Mã số sinh viên *Họ và tên *Điểm giữa kỳ (GK) *Điểm thực hành (TH) *Điểm lý thuyết (LT) Tính điểm tổng kết môn theo công thức: GK*10%+TH*30%+LT*60% 12
  13. * Viết chương trình nhập vào 2 thời gian t1 và t2 (thông tin thời gian gồm: giờ, phút và giây); tính khoảng cách giữa t1 và t2 (đơn vị tính bằng giây) 13
  14. * *Cách khai báo tương tựnhư mảng một chiều (Kiểu dữ liệu bây giờlà kiểu dữ liệu có cấu trúc). *Cách truy cập phần tửtrong mảng cũng như truy cập trên mảng một chiều. Nhưng do từng phần tửcó kiểu cấu trúc nên phải chỉ định rõ cần lấy thành phần nào, tức là phải truy cập đến thành phần cuối cùng có kiểu là dữliệu cơ bản (xem lại bảng các kiểu dữliệu cơ bản) 14
  15. * Do kiểu dữliệu có cấu trúc thường chứa rất nhiều thành phần nên khi viết chương trình loại này ta cần lưu ý: *Xây dựng hàm xửlýcho một kiểu cấu trúc. *Muốn xửlýcho mảng cấu trúc, ta gọi lại hàm xửlýcho một kiểu cấu trúc đã đượ c xây dựng bằng cách dùng vòng lặp. 15
  16. * Viết hàm nhập vào mảng các phân số struct ttPhanSo { int tu, mau; }; typedef struct ttPhanSo PHANSO; 16
  17. * void NhapPS(PHANSO &ps) { coutps.tu; coutps.mau; } 17
  18. * void NhapMangPS(PHANSO dsps[], int n) { for(int i=0; i
  19. * 3.1. Viết chương trình nhập vào mảng các phân số, cho biết phân số có giá trị lớn nhất trong mảng 3.2. Viết chương trình nhập vào danh sách các mặt hàng, in ra mặt hàng có xuất xứ “VietNam”, biết thông tin mặt hàng gồm: - Mã mặt hàng - Tên mặt hàng - Đơn giá - Xuất xứ 19
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
2=>2