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

Bài giảng Ngôn ngữ lập trình C - Chương 10: Mảng hai chiều

Chia sẻ: Bfvhgfff Bfvhgfff | Ngày: | Loại File: PDF | Số trang:10

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

Kết cấu chương 10 Mảng hai chiều thuộc bài giảng Ngôn ngữ lập trình C trình bày về những nội dung lần lượt như sau: khái niệm mảng hai chiều, khai báo mảng hai chiều, khởi tạo giá trị ban đầu cho mảng hai chiều, nập xuất mảng hai chiều, sử dụng mảng làm tham số truyền cho hàm.

Chủ đề:
Lưu

Nội dung Text: Bài giảng Ngôn ngữ lập trình C - Chương 10: Mảng hai chiều

  1. CHƯƠNG 6: MẢNG HAI CHIỀU Khái niệm • Mảng hai chiều có thể hiểu là một dãy các phần tử được sắp xếp liên tiếp trong bộ nhớ, từ hàng này sang hàng kia Khai báo mảng hai chiều • Cú pháp: • [][] • Các phần tử mảng được truy nhập bởi hai chỉ số: chỉ số dòng (bắt đầu từ 0 đến số dòng – 1) và chỉ số cột (bắt đầu từ 0 đến số cột – 1)
  2. • Ví dụ 1: int a[5][6] • Khai báo một mảng hai chiều gồm 30 phần tử, mỗi phần tử có kiểu int • Các phần tử của mảng a được phân bố trong bộ nhớ như sau: • a[0][0] a[0][1] … a[0][5] • a[1][0] a[1][1] … a[1][5] • … • a[4][0] a[4][1] … a[4][5]
  3. Khởi tạo giá trị ban đầu cho mảng hai chiều • Chúng ta có thể khởi tạo mảng hai chiều tương tự với việc khởi tạo mảng một chiều, bằng cách liệt kê các giá trị trong một danh sách. • Ví dụ 2: • int a[2][3] = { • {11, 12, 13}, • {21, 22, 23} • }; • Ví dụ 3: • float b[][4] = { • {6, 7. 8, 8, 9}, • {3, 12.6, 4, 14}, • {6.5, 20,7, 8} • };
  4. Nhập xuất mảng hai chiều • Ví dụ 4: • #define SIZE1 6 • #define SIZE2 8 • void main() • { int a[SIZE1][SIZE2]; /* khai báo một mảng 2 chiều nguyên gồm SIZE1*SIZE2 phần tử */ • int m, n; //lưu số dòng và số cột • int i, j, tam; • do • { • } while(m < 1 || m > SIZE1 || n < 1 || n > SIZE2); • // nhập dữ liệu cho mảng từ bàn phím • for(i = 0; i < m; i++) • for(j = 0; j < n; j++) • { printf(“pt thu [%d][%d]:”, i, j); • scanf(“%d”, &tam); • a[i][j] = tam; • } •
  5. • // xuất dữ liệu của mảng ra màn hình • for(i = 0; i < m; i++) • { • for(j = 0; j < n; j++) • printf(“%d\t”, a[i][j]); • printf(“\n”); • } • printf(“\n”); } Chú ý: Trong C đối với các phần tử của mảng hai chiều ta không thể sử dụng toán tử lấy địa chỉ (&). Tuy nhiên với mảng hai chiều nguyên thì dùng được.
  6. Sử dụng mảng làm tham số truyền cho hàm • Ví dụ 5: • #define SIZE1 5 • #define SIZE2 6 • // khai báo nguyên mẫu hàm • void Nhap(int (*a)[SIZE2], int *m, int *n); • void Xuất(int (*a)[SIZE2], int m, int n);
  7. • // định nghĩa hàm • void Nhap(int (*a)[SIZE2], int *m, int *n) • { • int tam; • do • { • printf(“Nhập so dong và so cot:”); • scanf(“%d%d”, &(*m), &(*n)); • } while(*m < 1 || *m > SIZE1 | |*n < 1 || *n > SIZE2); • for(i = 0; i < *m; i++) • for(j = 0; j < *n; j++) • { • printf(“pt thu [%d][%d]:”, i, j); • scanf(“%d”, &tam); • a[i][j] = tam; • } • }
  8. • void Xuat(int (*a)[SIZE2], int m, int n) • { • for(i = 0; i < m; i++) • { • for(j = 0; j < n; j++) • printf(“%d\t”, a[i][j]); • printf(“\n”); • } • } • void main() • { • float a[SIZE1][SIZE2]; • int m, n; • Nhap(a, &m, &n); • Xuat(a, m, n); • }
  9. • Chú ý: • Đối số thứ nhất của hai hàm trên có thể khai báo như một mảng hình thức như sau: • void Nhap(float a[][SIZE2], int *m, int *n); • void Xuat(float a[][SIZE2], int m, int n);
  10. Mảng vuông  Khi số dòng và số cột của một mảng hai chiều bằng nhau, chúng ta gọi mảng đó là mảng vuông (hay ma trận vuông). Số dòng và số cột của ma trận vuông gọi chung là kích thước ma trận vuông, ký hiệu là n.  Các phần tử nằm trên đường chéo chính là các phần tử a[i][i] với 0 ≤ i ≤ n- 1.  Các phần tử nằm trên đường chéo phụ là các phần tử a[n-1-i][i] với 0 ≤ i ≤ n-1.  Các phần tử nằm trong nửa mảng vuông phía trên đường chéo chính thỏa điều kiện i ≤ j.  Các phần tử nằm trong nửa mảng vuông phía trên đường chéo chính thỏa điều kiện i ≥ j.  Các phần tử nằm trong nửa mảng vuông phía trên đường chéo phụ thỏa điều kiện i +j ≤ n-1.  Các phần tử nằm trong nửa mảng vuông phía dưới đường chéo phụ thỏa điều kiện i +j ≥ n-1.
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

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