Danh mục

Bài giảng Lập trình nâng cao: Bài 5 - Hoàng Thị Điệp

Số trang: 51      Loại file: pdf      Dung lượng: 1.35 MB      Lượt xem: 12      Lượt tải: 0    
Hoai.2512

Phí tải xuống: 25,000 VND Tải xuống file đầy đủ (51 trang) 0
Xem trước 6 trang đầu tiên của tài liệu này:

Thông tin tài liệu:

Bài 5 giới thiệu mảng và cách sử dụng mảng với hàm. Nội dung chính trong bài này gồm có: Giới thiệu mảng, mảng và hàm, lập trình với mảng, mảng nhiều chiều. Mời các bạn cùng tham khảo để biết thêm các nội dung chi tiết.
Nội dung trích xuất từ tài liệu:
Bài giảng Lập trình nâng cao: Bài 5 - Hoàng Thị Điệp Bài 5: Mảng Giảng viên: Hoàng Thị ĐiệpKhoa Công nghệ Thông tin – ĐH Công Nghệ Chapter 5 ArraysCopyright © 2010 Pearson Addison-Wesley.All rights reserved Mục tiêu bài học• Giới thiệu mảng – Khai báo và tham chiếu mảng – Lệnh lặp for và mảng – Mảng trong bộ nhớ• Mảng và hàm – Hàm có đối số là mảng – Hàm có giá trị trả về là mảng• Lập trình với mảng – Mảng chưa đầy (Partially Filled Arrays) – Tìm kiếm, sắp xếp• Mảng nhiều chiềuDTH INT2202 Giới thiệu mảng• Định nghĩa mảng: – Tập hợp các phần tử dữ liệu cùng kiểu• Đây là kiểu dữ liệu “nhóm” đầu tiên ta học – int, float, double, char là những kiểu dữ liệu đơn• Dùng biểu diễn danh sách các phần tử giống nhau – Danh sách điểm thi, nhiệt độ, tên, … – Tránh khai báo nhiều biến đơn – Có thể thao tác với “danh sách” này như với một thực thểDTH INT2202 Khai báo mảng• Khai báo mảng  cấp phát bộ nhớ int score[5]; – Khai báo mảng 5 số nguyên, có tên là score – Tương tự như khai báo 5 biến: int score[0], score[1], score[2], score[3], score[4]• Mỗi cá thể trong mảng được gọi bằng rất nhiều tên: – Biến được đánh chỉ mục hoặc chỉ số – “Phần tử của mảng – Giá trị trong cặp ngoặc vuông gọi là chỉ số • Miền giá trị từ 0 tới size - 1DTH INT2202 Truy cập mảng• Phép truy cập sử dụng chỉ số – cout Sử dụng mảng• Cơ chế mạnh dùng cho lưu trữ• Có thể thực hiện những công việc như: – “Làm việc này với biến có chỉ số thứ i trong đó i được tính bởi chương trình – “Hiển thị tất cả các phần tử của mảng score – “Điền cho mảng score dữ liệu người dùng nhập vào – “Tìm giá trị lớn nhất trong mảng score – “Tìm giá trị nhỏ nhất trong mảng scoreDTH INT2202 Ví dụ chương trình dùng mảng: Display 5.1 Chương trình dùng mảng (1/2)DTH INT2202 Ví dụ chương trình dùng mảng: Display 5.1 Chương trình dùng mảng (2/2)DTH INT2202 Lệnh lặp for và mảng• for là lệnh lặp đếm tự nhiên – Có thể khảo sát lần lượt các phần tử trong mảng• Ví dụ: for (idx = 0; idx Lỗi lớn khi dùng mảng• Các chỉ số của mảng luôn bắt đầu từ 0• 0 là con số “đầu tiên” với người làm công nghệ thông tin• C++ sẽ “cho phép” bạn vượt ra ngoài miền này – Kết quả là không đoán trước được – Trình biên dịch sẽ không phát hiện ra những lỗi này!• Lập trình viên phải tự kiểm soát “miền” của chỉ sốDTH INT2202 Ví dụ về lỗi lớn khi dùng mảng• Miền chỉ số từ 0 tới (array_size – 1) – Ví dụ: double temperature[24]; // cỡ của mảng là 24 // Khai báo mảng 24 giá trị double có tên là temperature • Chúng được đánh chỉ số là: temperature[0], temperature[1] … temperature[23] – Lỗi thường gặp: temperature[24] = 5; • Chỉ số 24 nằm ngoài miền! • Không có cảnh báo, kết quả có thể rất tàn khốcDTH INT2202Dùng hằng có tên chỉ định kích thước mảng• Hãy dùng hằng có tên để chỉ định kích thước mảng• Ví dụ: const int NUMBER_OF_STUDENTS = 5; int score[NUMBER_OF_STUDENTS];• Dễ đọc hơn• Linh hoạt hơn• Dễ bảo trì hơnDTH INT2202 Dùng hằng có tên• Dùng ở mọi nơi cần tới kích thước của mảng – Khi duyệt vòng lặp for: for (idx = 0; idx < NUMBER_OF_STUDENTS; idx++) { // Thao tác với mảng } – Trong các phép tính liên quan kích thư ớc: lastIndex = (NUMBER_OF_STUDENTS – 1); – Khi truyền mảng vào hàm (sẽ bàn sau)• Nếu kích thước thay đổi  chỉ cần sửa mã nguồn ở một nơi trong chương trình!DTH INT2202 Mảng trong bộ nhớ• Nhắc lại: Những biến đơn – được cấp phát bộ nhớ bằng một “địa chỉ”• Khai báo mảng cấp phát bộ nhớ cho toàn bộ mảng• Cấp phát tuần tự – Nghĩa là các địa chỉ được cấp phát liền kề nhau – Có thể làm phép tính trên chỉ số • “Phép cộng” đơn giản từ địa chỉ đầu mảng (chỉ số 0)DTH INT2202 Một mảng trong bộ nhớDTH INT2202 Khởi tạo mảng• Các biến đơn có thể khởi tạo lúc khai báo: int price = 0; // 0 là giá trị khởi tạo• Cũng có thể làm vậy với mảng: int children[3] = {2, 12, 1}; – Tương đương vớ ...

Tài liệu được xem nhiều: