Viết chương trình cho phép
o Nhập các phần tử mảng từ bàn phím.
o In mảng
o Sắp xếp mảng tăng dần.
o Sắp xếp mảng giảm dần.
o Cho biết vị trị và giá trị phần tử lớn nhất, nhỏ nhất trong mảng.
o Cho biết mảng có bao nhiêu số nguyên tố, in ra danh sách các
số nguyên tố.
o Cho biết mảng có bao nhiêu số hoàn hảo, in ra danh sách các
số hoàn hảo.
o Cho phép thêm vào 1 phần tử ở đầu mảng, cuối mảng và ở vị tí
bất kỳ (nhập từ bàn phím).
o Cho phép xóa một phần tử ở đầu mảng, cuối mảng và xóa ở vị
trí bất kỳ (nhập từ bàn phím)
32 trang |
Chia sẻ: nguyenlam99 | Lượt xem: 1148 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Java - Mảng, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Mảng
7 20 5 9 3
0 1 2 3 4
a
Tên mảng
Giá trị
Chỉ số phần tử mảng
Trả lời câu hỏi
1. Mảng trên có mấy chiều?
2. Các phần tử của mảng có chung đặc điểm gì?
a. Màu sắc b. Hình dạng c. Số nguyên
3. Trong java, mảng trên được khai báo như thế
nào?
4. Cấu trúc lệnh nào thường dùng để duyệt
mảng?
a. IF b. For c. While
5. Tìm các số nguyên tố trong mảng trên?
NỘI DUNG MẢNG
oMảng một chiều
o Sao chép mảng
oMảng nhiều chiều
o Tìm kiếm phần tử trong mảng một chiều
o Sắp xếp các phần tử trong mảng một chiều
Kiểu dữ liệu mảng
Java có 2 kiểu dữ liệu cơ bản:
o Kiểu dữ liệu cơ sở: có 8 kiểu
o Kiểu dữ liệu tham chiếu (hay dẫn xuất): có 3 kiểu
- Kiểu mảng
- Kiểu lớp
- Kiểu giao tiếp (interface).
Kiểu dữ liệu mảng
o Khái niệm: Mảng là tập hợp nhiều phần tử
có cùng tên, cùng kiểu dữ liệu. Mỗi phần tử
trong mảng được truy xuất thông qua chỉ số
của nó trong mảng.
o Khai báo:
[];
hoặc
[] ;
o VD: int[] iarray; hoặc int iarray[];
int[] arrInt3, arrInt4, arrInt5;
Kiểu dữ liệu mảng
Cấp phát bộ nhớ cho mảng:
o Không giống C, C++
o Kích thước của mảng phải được xác định trước khi
khai báo:
o VD: int arrInt[100]; //sẽ báo lỗi
o Dùng từ khóa new để cấp phát bộ nhớ cho mảng.
o VD:
int iarrInt = new int[100];
Kiểu dữ liệu mảng
Khởi tạo giá trị cho mảng
o Có thể khởi tạo giá trị ban đầu cho các phần tử của
mảng khi nó được khai báo.
o VD:
int[] arrInt = {1, 2, 3, 5, 6};
char[] arrChar = {‘a’, ‘b’, ‘c’};
String arrString[] = {“Nguyen Van A”, “Tran Van B”};
Chú ý:
o Luôn khởi tạo hoặc cấp phát mảng trước khi sử dụng
o Một số khai báo không hợp lệ:
int[5] iarray;
int iarray[5];
Truy cập mảng
o Chỉ số mảng trong Java bắt đầu từ 0. Vì vậy phần tử
đầu tiên có chỉ số là 0, phần tử thứ n có chỉ số là n - 1.
o Các phần tử của mảng được truy xuất thông qua chỉ
số của nó đặt giữa cặp dấu ngoặc vuông ([]).
o VD:
int arrInt[] = {1, 2, 3};
int x = arrInt[0]; // x sẽ có giá trị là 1.
int y = arrInt[1]; // y sẽ có giá trị là 2.
int z = arrInt[2]; // z sẽ có giá trị là 3.
Chiều dài mảng – số phần tử mảng
o Lấy số phần tử mảng ta dùng lệnh tenmang.length
o VD:
int a[]=new int[10];
int b[]={1,3,5};
Kết quả:
a.length=10;
b.length=3;
Một số ví dụ về mảng
//Nhập và xuất giá trị các phần tử của một mảng các số nguyên:
public class ArrayDemo {
public static void main(String[] args) {
int arrInt[] = new int[10];
int i;
for(i = 0; i < arrInt.length; i ++)
arrInt[i] = i;
for(i = 0; i < arrInt.length; i ++)
System.out.println("This is arrInt[" + i +"]: " +
arrInt[i]);
}
}
Một số ví dụ về mảng
//Tìm phần tử có giá trị nhỏ nhất (Min) và lớn nhất (Max) trong
một mảng.
public class TimMaxMin {
public static void main(String[] args) {
int nums[] = { 99, -10, 100123, 18, -978, 5623, 463, -9,
287, 49 };
int min, max;
min = max = nums[0];
for(int i=1; i < 10; i++){
if(nums[i] < min) min = nums[i];
if(nums[i] > max) max = nums[i];
}
System.out.println("Min and max: " + min + " " + max);
} }
Một số ví dụ về mảng
import java.util.Scanner;
public class BTMang {
public static void main(String[] args) {
Scanner input =new Scanner(System.in);
int [] a = new int[5];
int i, j, tg;
//nhap mang
System.out.println("Nhap vao cac phan tu
cua mang");
for(i=0;i< a.length;i++){
System.out.print("a"+"["+i+"]"+"=" );
a[i]=input.nextInt();
}
//in mang
System.out.println("Mang vua nhap:");
for(i=0;i<a.length;i++){
System.out.print(a[i] + " ");
}
System.out.println("");
//sap xep mang
System.out.println("Sap xep cac phan
tu cua mang theo chieu tang dan:");
for(i=0;i<a.length;i++){
for(j=i+1;j<a.length;j++){
if(a[i]>a[j]){
tg=a[i];
a[i]=a[j];
a[j]=tg;
}
}
System.out.print(a[i] + " ");
}
}
}
Một số ví dụ về mảng
import java.util.Scanner;
public class BTMang2 {
public static void Nhap(int[] a){
Scanner input =new Scanner(System.in);
System.out.println("Nhap vao cac phan
tu cua mang");
for(int i=0;i< a.length;i++){
System.out.print("a"+"["+i+"]"+"=" );
a[i]=input.nextInt();
}
}
public static void In(int[] a){
System.out.println("Mang vua nhap:");
for(int i=0;i<a.length;i++){
System.out.print(a[i] + " ");
}
System.out.println("");
}
public static void Sapxep(int[] a){
int i, j, tg;
System.out.println("Sap xep cac phan
tu cua mang theo chieu tang dan:");
for(i=0;i<a.length;i++){
for(j=i+1;j<a.length;j++){
if(a[i]>a[j]){
tg=a[i];
a[i]=a[j];
a[j]=tg;
}
}
System.out.print(a[i] + " ");
}
}
public static void main(String[] args) {
}
Một số ví dụ về mảng
public static void main(String[] args) {
int [] a = new int[5];
BTMang2 m2 = new BTMang2();
m2.Nhap(a);
//in mang
m2.In(a);
m2.Sapxep(a);
}
}
• int[] sourceArray = {2, 3, 1, 5, 10};
• int[] targetArray = new int[sourceArray.length];
• for (int i = 0; i < sourceArray.length; i++)
• targetArray[i] = sourceArray[i];
Sử dụng một vòng lặp:
• targetArray = sourceArray;
Dùng lệnh gán: Gán tham chiếu của
sourceArray cho targerArray
• System.arraycopy(srcArray, src_pos, tarArray, tar_pos,
length);
Dùng tiện ích arraycopy
Sao chép mảng
import java.util.*;
public class randomfile {
public static void main(String[] args) {
int[] s = {1,3,5,7,9,11,13,15};
int[] d = {2,4,6,8,10,12,14};
System.out.println(" mang d ban dau ");
for(int i =0; i< d.length; i++){
System.out.print(" "+d[i]);
}
System.out.print("\n");
System.arraycopy(s,3,d,2,4);
System.out.println(" mang d sau");
for(int i =0; i< d.length; i++){
System.out.print(" "+d[i]);
} }
}
copy 4 phần tử của mảng
s, bắt đầu tại vị trí thứ 3
là 7,9,11,13 rồi chép sang
mảng d, bắt đầu tại vị trí
thứ 2 -> kết quả mảng d:
phần tử 6,8,10,12 được
thay bằng 7,9,11,13
Sao chép mảng
Mảng nhiều chiều
o Khai báo n chiều trong java
[][]...[] ;
hoặc
[][]..[]
o Ví dụ khai báo mảng 2 chiều
int a[][];
int[][] a;
Mảng nhiều chiều
o Khai báo 1 mảng kèm theo cấp phát bộ nhớ cho mảng
n chiều
[][]...[] = new <Kiểu
dữ liệu>[Số phần từ 1][Số phần tử 2].....[Số phần tử n]
o Ví dụ khai bào mảng 2 chiều (ma trận 2 hàng 3 cột)
int a[][]=new int[2][3];
Mảng nhiều chiều
o Truy xuất đến phần tử của mảng nhiều chiều A ta
dùng cú pháp A[n-1][m-1]...[k-1];
o Ví dụ truy xuất mảng 2 chiều
int a[][]={ {3,4},
{2,8},
};
o Lúc đó:
a[0][0]=3;
a[0][1]=4;
a[1][0]=2;
a[1][1]=8;
• Lấy số dòng của mảng: ArrayName.length
• Lấy số phần tử của dòng i: ArrayName[i].length
• Ví dụ: Cho mảng sau:
int[][] array = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}, {10, 11, 12}};
– Khi đó:
array.length cho kết quả là 4.
array[0].length cho kết quả là 3
Độ dài mảng nhiều chiều
Một số ví dụ về mảng
// Nhập và xuất giá trị của các phần tử trong một mảng hai chiều
public class TwoD_Arr {
public static void main(String[] args) {
int t, i;
int mang[][] = new int[3][4];
for(t=0; t < 3; ++t){
for(i=0; i < 4; ++i){
mang[t][i] = (t*4)+i+1;
System.out.print(mang[t][i] + “ “);
}
System.out.println();
}
}
}
Lớp java.util.Arrays
• Cung cấp một số phương thức xử lý các mảng:
– public static int binarySearch(double[ ] a, double x )
– public static boolean equals( double[ ] a, double[] b)
– public static void fill( double[ ] a, double x)
– public static void fill( double[ ] a, int lo, int hi,
double x)
– public static void sort( double[ ] a )
• Mỗi phương thức trên có cách thực hiện khác nhau cho
các kiểu dữ liệu cơ sở (byte, short, int, long, float,
double, char và boolean) và kiểu đối tượng.
Tìm kiếm trong mảng
• Tìm kiếm là quá trình tìm một phần tử xác định trong
mảng.
– Ví dụ: Tìm một sinh viên trong danh sách SV.
• Tìm kiếm là một thao tác cơ bản trong lập trình.
• Có nhiều giải thuật và cấu trúc dữ liệu để tìm kiếm. Hai
giải thuật cơ bản là: tìm kiếm tuyến tính (linear search)
và tìm kiếm nhị phân (binary search).
Tìm kiếm tuyến tính
• Phương pháp tìm kiếm tuyến tính so sánh phần tử
khóa key với mỗi phần tử trong mảng.
• Việc tìm kiếm sẽ kết thúc khi tìm thấy một phần tử
mảng bằng key hoặc khi duyệt hết mảng mà không tìm
thấy.
• Ví dụ minh họa: Tạo một mảng 2 chiều (7 x 9) có các
phần tử là các số nguyên ngẫu nhiên nằm trong [0-
1000) rồi hiển thị ra màn hình. Nhập số n từ bàn phím.
Tìm kiếm và trả về số lần xuất hiện của tất cả các phần
tử có giá trị bằng số vừa nhập vào. Nếu không tìm thấy
thì in ra chuỗi “Khong tim thay!”.
Tìm kiếm nhị phân
• Để thực hiện được tìm kiếm nhị phân, các phần tử
mảng phải được sắp xếp theo thứ tự tăng/giảm dần.
Giả sử mảng được sắp xếp tăng dần:
2 4 7 10 11 45 50 59 60 66 69 70 79
Tìm kiếm nhị phân
• Trước tiên so sánh giá trị cần tìm (key) với phần tử
nằm giữa mảng. Có thể xảy ra 3 trường hợp sau:
– Nếu key bằng phần tử giữa ⇒ kết thúc vì tìm
thấy.
– Nếu key nhỏ hơn phần tử giữa, lặp lại việc tìm
key trong nửa đầu của mảng theo phương pháp
nhị phân.
– Nếu key lớn hơn phần tử giữa, lặp lại việc tìm
key trong nửa cuối của mảng theo phương
pháp nhị phân.
Tìm kiếm nhị phân
Tìm kiếm nhị phân
• Viết chương trình tạo và nhập dữ liệu cho mảng 1
chiều có 10 phần tử kiểu int có giá trị tăng dần rồi in ra
màn hình. Nhận một số từ bàn phím, tìm kiếm nhị phân
rồi trả về vị trí của phần tử tìm được. Nếu không tìm
thấy thì in ra chuỗi “Không tìm thấy!”.
Sắp xếp mảng
• Hoán đổi vị trí các phần tử trong mảng để có được một
mảng trong đó các phần tử có thứ tự tăng/giảm dần
• Có nhiều thuật toán có thể được dùng để sắp xếp:
– Chọn (selection sort): Tìm phần tử lớn trong mảng
rồi đổi chỗ với phần tử cuối cùng của mảng
– Nổi bọt (bubble sort): So sánh một phần tử với
phần tử kế nó, nếu lớn hơn thì đổi chỗ
– Trộn (Merge sort),
Sắp xếp chọn
Mảng chưa sắp xếp: int[] myList = {2, 9, 5, 4, 8, 1, 6};
2, 9, 5, 4, 8, 1, 6 => 2, 6, 5, 4, 8, 1, 9 (Số PT = 7)
2, 6, 5, 4, 8, 1 => 2, 6, 5, 4, 1, 8 (Số PT = 6)
2, 6, 5, 4, 1 => 2, 1, 5, 4, 6 (Số PT = 5)
2, 1, 5, 4 => 2, 1, 4, 5 (Số PT = 4)
2, 1, 4 => 2, 1, 4, (Số PT = 3)
2, 1 => 1, 2
Kết quả: 1, 2, 4, 5, 6, 8, 9
Sắp xếp nổi bọt
Dãy chưa sắp xếp: int[] myList = {2, 9, 5, 4, 8, 1, 6};
Lần 1: 2, 5, 4, 8, 1, 6, 9
Lần 2: 2, 4, 5, 1, 6, 8, 9
Lần 3: 2, 4, 1, 5, 6, 8, 9
Lần 4: 2, 1, 4, 5, 6, 8, 9
Lần 5: 1, 2, 4, 5, 6, 8, 9
Lần 6: 1, 2, 4, 5, 6, 8, 9
Viết chương trình cho phép
o Nhập các phần tử mảng từ bàn phím.
o In mảng
o Sắp xếp mảng tăng dần.
o Sắp xếp mảng giảm dần.
o Cho biết vị trị và giá trị phần tử lớn nhất, nhỏ nhất trong mảng.
o Cho biết mảng có bao nhiêu số nguyên tố, in ra danh sách các
số nguyên tố.
o Cho biết mảng có bao nhiêu số hoàn hảo, in ra danh sách các
số hoàn hảo.
o Cho phép thêm vào 1 phần tử ở đầu mảng, cuối mảng và ở vị tí
bất kỳ (nhập từ bàn phím).
o Cho phép xóa một phần tử ở đầu mảng, cuối mảng và xóa ở vị
trí bất kỳ (nhập từ bàn phím).
Một số ví dụ về mảng
Các file đính kèm theo tài liệu này:
- java_chuong_5_mang_4198.pdf