Các Kỹ Thuật Lập Trình Với Mảng 2 Chiều Và Minh Họa Với C++
Có thể bạn quan tâm
1. Nhập xuất mảng 2 chiều
Sử dụng 2 vòng lặp for để duyệt hàng và cột để nhập xuất mảng hai chiều
#include <iostream> using namespace std; int main() { int temp[3][4]; cout<<"input temp array:"<<endl; for(int i=0;i<3;i++){ for(int j=0;j<4;j++){ cout<<"temp["<<i<<"]["<<j<<"]="; cin>>temp[i][j]; } cout<<"\n"; } cout<<"output temp array:"<<endl; for(int i=0;i<3;i++){ for(int j=0;j<4;j++){ cout<<temp[i][j]<<" "; } cout<<"\n"; } system("pause"); }Kết quả
input temp array: temp[0][0]=1 temp[0][1]=2 temp[0][2]=5 temp[0][3]=9 temp[1][0]=1 temp[1][1]=5 temp[1][2]=7 temp[1][3]=2 temp[2][0]=0 temp[2][1]=1 temp[2][2]=5 temp[2][3]=7 output temp array: 1 2 5 9 1 5 7 2 0 1 5 72. Nhập xuất mảng 2 chiều với hàm
Có thể khai báo mảng hai chiều trước, sau đó, dùng hàm nhập mảng thì nhập số dòng và số cột thật sự của mảng. Số dòng và số cột lúc khai báo phải lớn hơn hoặc bằng số dòng và số cột thật sự lúc nhập, nếu không sẽ có thể gây ra lỗi dữ liệu rác.#include <iostream> using namespace std; #define MAXR 100 //max column #define MAXC 100 //max row void inputArray(int a[][MAXC], int &m, int &n){ cout<<"input number of row:"; cin>>m; cout<<"input number of column:"; cin>>n; cout<<"input two dimensional array "<<m<<"x"<<n<<":"<<endl; for(int i=0;i<m;i++){ for(int j=0;j<n;j++){ cout<<"a["<<i<<"]["<<j<<"]="; cin>>a[i][j]; } cout<<"\n"; } } void outputArray(int a[][MAXC], int m, int n){ cout<<"output two dimensional array "<<m<<"x"<<n<<":"<<endl; for(int i=0;i<m;i++){ for(int j=0;j<n;j++){ cout<<a[i][j]<<" "; } cout<<"\n"; } } int main() { int temp[MAXR][MAXC]; int m, n; inputArray(temp, m, n); outputArray(temp, m, n); system("pause"); }
Kết quả
input number of row:2 input number of column:3 input two dimensional array 2x3: a[0][0]=1 a[0][1]=3 a[0][2]=1 a[1][0]=4 a[1][1]=5 a[1][2]=3 output two dimensional array 2x3: 1 3 1 4 5 3Các biến lưu trữ số dòng và số cột thật sự phải truyền tham chiếu để sau khi ra khỏi hàm vẫn còn lưu được các giá trị này để xuất hoặc tính toán trên mảng.
3. Tìm kiếm phần tử trong mảng 2 chiều
Yêu cầu: Tìm xem phần tử x có nằm trong ma trận a kích thước mxn hay không?
Ý tưởng: Duyệt từng phần của ma trận a. Nếu phần tử đang xét bằng x thì trả về có (1), ngược lại trả về không có (0).#include <iostream> using namespace std; int FindX(int a[2][3], int x) { int i, j; for (i=0; i<2; i++){ for (j=0; j<3; j++){ if (a[i][j] == x){ return 1; } } } return 0; } int main() { int temp[2][3]={{0, 5, 1},{8, -1, 2}}; //find -1 in temp array int result = FindX(temp, -1); if(result == 1){ cout<<"Find -1 in temp array"; }else{ cout<<"Not find -1 in temp array"; } system("pause"); }
Kết quả
Find -1 in temp array4. Tính tổng các phần tử trong mảng hai chiều
Yêu cầu: Cho trước ma trận a, kích thước mxn. Tính tổng các phần tử trong mảng.
Ý tưởng: Duyệt từng phần của ma trận a rồi cộng dồn các phần tử.#include <iostream> using namespace std; int sumArray(int a[2][3]) { int i, j, sum=0; for (i=0; i<2; i++){ for (j=0; j<3; j++){ sum = sum + a[i][j]; } } return sum; } int main() { int temp[2][3]={{0, 5, 1},{8, -1, 2}}; //sum elements in temp array int result = sumArray(temp); cout<<"Sum elements in temp array = "<<result; system("pause"); }
Kết quả
Sum elements in temp array = 155. Tìm max trong mảng hai chiều
Yêu cầu: Cho trước ma trận a, kích thước mxn. Tìm giá trị lớn nhất trong ma trận a (gọi là max).
Ý tưởng: Giả sử giá trị max hiện tại là giá trị phần tử đầu tiên a[0][0]. Lần lượt kiểm tra các phần tử còn lại để cập nhật max.
- Đối tượng (object) và cách sử dụng đối tượng trong Java
- Đọc (read) file JSON với Python
- Cách sử dụng câu lệnh break, continue và go to trong C++
- Các kiểu dữ liệu (data type) cơ bản trong Python
- Mở (open) và đọc (read) tập tin (file) với Python
Kết quả
Max in temp array = 8 4.3/5 - (6 bình chọn)Bài trước và bài sau trong môn học<< Mảng hai chiều là gì? Cách khai báo và khởi tạo trong C++Kiểu dữ liệu cấu trúc (struct) trong C++: định nghĩa và khai báo biến >>Từ khóa » Tìm Max Trong Mảng 2 Chiều Java
-
Java - Tìm Giá Trị Lớn Nhất Trong Một Ma Trận 2 Chiều Với Các Phần Tử ...
-
Mảng Hai Chiều Trong Java - Freetuts
-
Tìm Phần Tử Lớn Nhất Trong Mảng Hai Chiều Java - Học Tốt
-
Tìm Số Lớn Thứ 2 Trong Mảng - Java Code - Deft Blog
-
Tìm Vị Trí Có Giá Trị Lớn Nhất Trong Mảng 2 Chiều - Dungnv
-
Bài 54. Tìm Giá Trị Lớn Nhất Và Tìm Giá Trị Nhỏ Nhất Của Ma Trân Hai Chiều
-
Tim MAX,MIN Của Mảng 2 Chiều
-
Tim MAX,MIN Của Mảng 2 Chiều - Programming - Dạy Nhau Học
-
Bài Tập Về Mảng Trong Java: Tìm Phần Tử Lớn Nhất Trong Mảng.
-
Tìm Phần Tử Lớn Nhất Trong Mảng C | Lập Trình Từ Đầu
-
Bài 55. Bài Tập Mảng 2 Chiều Có Lời Giải Code C/C++
-
Tìm Các Giá Trị Lớn Nhất Trong Từng Hàng (hoặc Cột) Của Ma Trận?
-
Kỹ Thuật Lập Trình Với Mảng 1 Chiều Trong Java