Bài giảng Lý thuyết hệ điều hành - Chương 10: Ứng dụng đa xạ - Nguyễn Tấn
Bài toán: Một cái máy có nhiều chi
tiết. Mỗi chi tiết máy có thể là chi tiết
đơn hoặc là chi tiết phức.
Chi tiết đơn: là chi tiết không chứa
bên trong nó chi tiết khác. Thông tin
của chi tiết đơn bao gồm: mã số chi
tiết, giá tiền.
Chi tiết phức: là chi tiết chứa bên
trong nó nhiều chi tiết thành phần, mỗi
một chi tiết thành phần này có thể là
chi tiết đơn hoặc là chi tiết phức.
Thông tin của chi tiết phức bao gồm:
mã số chi tiết, số lượng chi tiết thành
phần, danh sách các chi tiết thành
phần. Giá tiền của chi tiết phức bằng
tổng giá tiền của các chi tiết thành
phần.
N CHI TIẾT MÁY Yêu cầu: Thiết kế các lớp thích hợp để thực hiện các yêu cầu sau: Nhập các chi tiết cho máy. Tìm kiếm một chi tiết máy theo mã số. Tính tiền cho một chi tiết máy, hoặc cho máy. Xuất các chi tiết máy. Đếm số lượng chi tiết đơn có trong cái máy. Chương 14 - 4 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Sơ đồ lớp sơ bộ CChiTiet CChiTietPhucCChiTietDon CMay Có Chương 14 - 5 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Sơ đồ lớp chi tiết CChiTiet CChiTietPhucCChiTietDon CMay Có MaSo GiaTien MaSo n CChiTiet ds[100] MaSo n CChiTiet ds[100] public Nhap() Nhap() Nhap() Nhap() Xuat() Xuat() Xuat() Xuat() CChiTiet TimKiem(long) CChiTiet TimKiem(long) CChiTiet TimKiem(long) CChiTiet TimKiem(long) float TinhTien() float TinhTien() float TinhTien() float TinhTien() Chương 14 - 6 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 1. class CChiTiet 2. { 3. protected: 4. long maso; 5. public: 6. void Nhap(); 7. void Xuat(); 8. float TinhTien(); 9. CChiTiet TimKiem(long); 10.}; Chương 14 - 7 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 1. class CChiTietDon:public CChiTiet 2. { 3. protected: 4. float giatien; 5. public: 6. void Nhap(); 7. void Xuat(); 8. float TinhTien(); 9. CChiTiet TimKiem(long); 10.}; Chương 14 - 8 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 1. class CChiTietPhuc:public CChiTiet 2. { 3. protected: 4. int n; 5. CChiTiet ds[100]; 6. public: 7. void Nhap(); 8. void Xuat(); 9. float TinhTien(); 10. CChiTiet TimKiem(long); 11.}; Chương 14 - 9 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 1. class CMay 2. { 3. protected: 4. int n; 5. CChiTiet ds[100]; 6. public: 7. void Nhap(); 8. void Xuat(); 9. float TinhTien(); 10. CChiTiet TimKiem(long); 11.}; Chương 14 - 10 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. void CChiTiet::Nhap() 2. { 3. return; 4. } Chương 14 - 11 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. void CChiTiet::Xuat() 2. { 3. return; 4. } Chương 14 - 12 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. float CChiTiet::TinhTien() 2. { 3. return 0; 4. } Chương 14 - 13 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. CChiTiet CChiTiet::TimKiem(long ms) 2. { 3. if() 4. return 5. else 6. return 7. } Chương 14 - 14 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. void CChiTietDon::Nhap() 2. { 3. print(“Nhap ma so:”); 4. scanf(“%ld”,&maso); 5. float temp; 6. printf(“Nhap gia tien:”); 7. scanf(“%f”,&temp); 8. giatien = temp; 9. } Chương 14 - 15 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. void CChiTietDon::Xuat() 2. { 3. printf(“(%ld(%8.3f))”, maso,giatien); 4. } Chương 14 - 16 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. float CChiTietDon::TinhTien() 2. { 3. return giatien; 4. } Chương 14 - 17 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. CChiTiet CChiTietDon::TimKiem(long ms) 2. { 3. if() 4. return 5. else 6. return 7. } Chương 14 - 18 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. float CChiTietPhuc::TinhTien() 2. { 3. float s = 0; 4. for(int i=0;i<n;i++) 5. s=s+ds[i].TinhTien(); 6. return s; 7. } Chương 14 - 19 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 1. class CChiTietPhuc:public CChiTiet 2. { 3. protected: 4. int n; 5. CChiTiet* ds[100]; 6. public: 7. void Nhap(); 8. void Xuat(); 9. float TinhTien(); 10. CChiTiet TimKiem(long); 11.}; Chương 14 - 20 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 1. class CMay 2. { 3. protected: 4. int n; 5. CChiTiet* ds[100]; 6. public: 7. void Nhap(); 8. void Xuat(); 9. float TinhTien(); 10. CChiTiet TimKiem(long); 11.}; Chương 14 - 21 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. float CChiTietPhuc::TinhTien() 2. { 3. float s = 0; 4. for(int i=0;i<n;i++) 5. s=s+ds[i]->TinhTien(); 6. return s; 7. } Chương 14 - 22 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 11.class CChiTiet 12.{ 13. protected: 14. long maso; 15. public: 16. virtual void Nhap(); 17. virtual void Xuat(); 18. virtual float TinhTien(); 19. virtual CChiTiet TimKiem(long); 20.}; Chương 14 - 23 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. float CChiTietPhuc::TinhTien() 2. { 3. float s = 0; 4. for(int i=0;i<n;i++) 5. s=s+ds[i]->TinhTien(); 6. return s; 7. } Chương 14 - 24 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. void CChiTietPhuc::Xuat() 2. { 3. printf(“\n Ma so:%ld”, maso); 4. for(int i=0;i<n;i++) 5. ds[i]->Xuat(); 6. } Chương 14 - 25 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 1. class CChiTiet 2. { 3. protected: 4. long maso; 5. public: 6. virtual void Nhap(); 7. virtual void Xuat(); 8. virtual float TinhTien(); 9. virtual CChiTiet*TimKiem(long); 10.}; Chương 14 - 26 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 1. class CChiTietDon:public CChiTiet 2. { 3. protected: 4. float giatien; 5. public: 6. void Nhap(); 7. void Xuat(); 8. float TinhTien(); 9. CChiTiet*TimKiem(long); 10.}; Chương 14 - 27 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 1. class CChiTietPhuc:public CChiTiet 2. { 3. protected: 4. int n; 5. CChiTiet* ds[100]; 6. public: 7. void Nhap(); 8. void Xuat(); 9. float TinhTien(); 10. CChiTiet*TimKiem(long); 11.}; Chương 14 - 28 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Khai báo lớp 1. class CMay 2. { 3. protected: 4. int n; 5. CChiTiet* ds[100]; 6. public: 7. void Nhap(); 8. void Xuat(); 9. float TinhTien(); 10. CChiTiet*TimKiem(long); 11.}; Chương 14 - 29 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Sơ đồ lớp chi tiết CChiTiet CChiTietPhucCChiTietDon CMay Có MaSo GiaTien MaSo n CChiTiet ds[100] MaSo n CChiTiet ds[100] public Nhap() Nhap() Nhap() Nhap() Xuat() Xuat() Xuat() Xuat() CChiTiet *TimKiem(long) CChiTiet *TimKiem(long) CChiTiet*TimKiem(long) CChiTiet *TimKiem(long) float TinhTien() float TinhTien() float TinhTien() float TinhTien() Chương 14 - 30 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. CChiTiet*CChiTiet::TimKiem(long ms) 2. { 3. if(maso==ms) 4. return this; 5. else 6. return NULL; 7. } Chương 14 - 31 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. CChiTiet*CChiTietDon::TimKiem(long ms) 2. { 3. if(maso==ms) 4. return this; 5. else 6. return NULL; 7. } Chương 14 - 32 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. CChiTiet*CChiTietPhuc::TimKiem(long ms) 2. { 3. if(maso==ms) 4. return this; 5. for(int i=0;i<n;i++) 6. { 7. CChiTiet*kq=ds[i]->TimKiem(ms); 8. if(kq!=NULL) 9. return kq; 10. } 11. return NULL; 12.} Chương 14 - 33 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY 1. void CChiTietPhuc::Nhap() 2. { 3. printf(“Nhap ma so:”); 4. scanf(“%ld”,&maso); 5. printf(“Nhap n:”); 6. scanf(“%d”,&n); 7. for(int i=0;i<n;i++) 8. { 9. printf(“Nhap a[%d]:”,i); 10. ds[i]->Nhap(); 11. } 12.} Chương 14 - 34 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 11.void CChiTietPhuc::Nhap() 12.{ 13. printf(“Nhap ma so:”); 14. scanf(“%ld”,&maso); 15. printf(“Nhap n:”); 16. scanf(“%d”,&n); 17. int loai; 18. for(int i=0;i<n;i++) 19. { 20. printf(“Nhap loai chi tiet (0.Don, 1. Phuc):”); 21. scanf(“%d”,&loai); 22. switch(loai) 23. { 24. case 0:ds[i]=new CChiTietDon; 25. break; 26. case 1:ds[i]=new CChiTietPhuc; 27. break; 28. } 29. ds[i]->Nhap(); 30. } 31.} Chương 14 - 35 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. float CMay::TinhTien() 2. { 3. float s = 0; 4. for(int i=0;i<n;i++) 5. s=s+ds[i]->TinhTien(); 6. return s; 7. } Chương 14 - 36 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 1. void CMay::Xuat() 2. { 3. for(int i=0;i<n;i++) 4. ds[i]->Xuat(); 5. } Chương 14 - 37 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 1. BÀI TOÁN CHI TIẾT MÁY Định nghĩa phương thức 11.CChiTiet*CMay::TimKiem(long ms) 12.{ 13. for(int i=0;i<n;i++) 14. { 15. CChiTiet*kq=ds[i]->TimKiem(ms); 16. if(kq!=NULL) 17. return kq; 18. } 19. return NULL; 20.} Chương 14 - 38 LTHĐTKhoa CNTT ThS. Nguyễn Tấn Trần Minh Khang 11.void CMay::Nhap() 12.{ 13. printf(“Nhap n:”); 14. scanf(“%d”,&n); 15. int loai; 16. for(int i=0;i<n;i++) 17. { 18. printf(“Nhap loai chi tiet (0.Don, 1. Phuc):”); 19. scanf(“%d”,&loai); 20. switch(loai) 21. { 22. case 0:ds[i]=new CChiTietDon; 23. break; 24. case 1:ds[i]=new CChiTietPhuc; 25. break; 26. } 27. ds[i]->Nhap(); 28. } 29.}
File đính kèm:
- bai_giang_ly_thuyet_he_dieu_hanh_chuong_10_ung_dung_da_xa_ng.pdf