Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống
1
/ 47 trang
THÔNG TIN TÀI LIỆU
Thông tin cơ bản
Định dạng
Số trang
47
Dung lượng
167,4 KB
Nội dung
* CH NG 5ƯƠ M NG M T CHI UẢ Ộ Ề 9 / 4 / 1 5 1 9/4/15 2 * KHÁI NI MỆ * Mang th c châ t la môt biê n đ c câ p pha t bô nh liên ́ ̀ ́ ́ ́ ́̉ ự ̣ ượ ̣ ơ tuc va bao gô m nhiê u biê n tha nh phâ n.̀ ̀ ̀ ́ ̀ ̣̀ * Ca c tha nh phâ n cua mang la tâp h p ca c biê n co cu ng ́ ̀ ̀ ̀ ́ ́ ́ ̀̉ ̉ ̣ ợ kiêu d liêu va cu ng tên. Do đo đê truy xuâ t ca c biê n ̃ ̀ ̀ ́ ́ ́ ́̉ ư ̣ ̉ tha nh phâ n, ta du ng c chê chi muc.̀ ̀ ̀ ́ơ ̉ ̣ 0 1 2 3 4 5 6 7 8 9 Giá trị V tríị V trí đ c tính t 0ị ượ ừ 9/4/15 3 * KHAI BÁO * * * < Kiểu dữ liệu > < Tên mảng > [ < Số phần tử tối đa của mảng> ] ; Nh m thu n ti n cho vi c vi t ch ng trình, ta nên đ nh ằ ậ ệ ệ ế ươ ị nghĩa h ng s MAX đ u ch ng trình – là kích th c t i đa ằ ố ở ầ ươ ướ ố c a m ng - nh sau:ủ ả ư #define MAX 100 void main() { int a[MAX], b[MAX]; //Các l nhệ } 9/4/15 4 * KHAI BÁO VÀ GÁN GIÁ TR BAN Ị Đ U CHO M NGẦ Ả Gán t ng ph n từ ầ ử int a[5] = {3, 6, 8, 1, 12}; Gán toàn b ph n t có cùng giá trộ ầ ử ị int a[8] = {3}; Giá trị 3 6 8 1 12 V tríị 0 1 2 3 4 Giá trị 3 3 3 3 3 3 3 3 V tríị 0 1 2 3 4 5 6 7 9/4/15 5 * TRUY XU T GIÁ TRẤ Ị TênMảng [vị trí cần truy xuất] void main() { int a[5] = {3, 6, 8, 11, 12}; cout<<“Giá tr m ng t i v trí 3 = “<<a[3];ị ả ạ ị } K t qu : Giá tr m ng t i v trí 3 = 11ế ả ị ả ạ ị V trí 3ị 9/4/15 6 * CÁC THAO TÁC TRÊN M NGẢ * Nh pậ * Xu t (li t kê)ấ ệ * Tìm ki mế * Đ mế * S p x pắ ế * Ki m tra m ng th a đi u ki n cho tr cể ả ỏ ề ệ ướ * Tách/ ghép m ngả * Chèn / xóa 9/4/15 7 * NH P XU T M NGẬ Ấ Ả !" #$% &'( ) &*+,,( ) ++-%-++++ - // 0 0 # 9/4/15 8 $" &'( ) &*+,,( ++++-12 0 # $&( ) !"' ++-%.- // % &'( ++-3$.2++ " &'( 0 9/4/15 9 * LI T KÊ CÁC PH N T TH A ĐK CHO TR CỆ Ầ Ử Ỏ ƯỚ M u 1: ẫ void LietKeXXX(int a[], int n) { for (int i = 0; i<n; i++) if (a[i] ỏ đi u ki nề ệ ) Xu t a[i];ấ } M u 2: ẫ void LietKeXXX(int a[], int n, int x) { for (int i = 0; i<n; i++) if (a[i] ỏ đi u ki n ề ệ $ 4ớ ) Xu t a[i];ấ } 9/4/15 10 Ví d 1:ụ Li t kê các ph n t có giá tr ch n trong m ngệ ầ ử ị ẵ ả void LietKeChan(int a[], int n) { for (int i = 0; i<n; i++) if (a[i] %2 ==0) cout<<a[i]<<“\t”; } Ví d 2:ụ Li t kê các ph n t có giá tr l n h n x trong m ngệ ầ ử ị ớ ơ ả void LietKeLonHonX(int a[], int n, int x) { for (int i = 0; i<n; i++) if (a[i] > x) cout<<a[i]<<“\t”; } [...]... với phần tử thứ nhất, thứ hai, c a mảng a cho đến khi gặp đư c phần tử c n tìm, ho c đã tìm hết mảng mà không thấy x Minh họa tìm x =10 10 7 5 12 41 10 32 13 9 15 3 1 2 3 4 5 6 7 8 9 10 Minh họa tìm x = 25 25 7 5 12 41 10 32 13 9 15 3 1 2 3 4 5 6 7 8 9 10 31 Chưa Đã tìm thấy tại hết vị trí 5 mảng Chưa Đã hết hết mảng mảng *CODE MINH HỌA (nếu x không xuất hiện trong mảng trả về -1) int TimVTX(int a[],... 10 1 5 7 2 3 3 4 15 9 5 1 6 2 7 8 25 1 nhỏ hơn 3 Bư c 2: So sánh giá trị tại vtmin với tất c nên c p giá trị tại ậị trí trí lại (từ 2 đến 8), nếu c v t vị c n nh phần tử nào nhỏ hơn phần tử tại vtmin thì min c p nhật lại vtmin vtmin 10 1 5 7 2 3 3 4 15 9 5 1 6 2 7 8 26 15 lớn hơn 1 Bư c 2: So sánh giá trị tại vtmin với tất c nên không giá trị tcập nhậtcòn lại (từ 2 đến 8), nếu c ại vị trí vị phần... 8), nếu c 5 nhỏ hơn phần tử nào nhỏ hơn phần tử tại vtmin thì 10 nên c p c p nhật lại vtmin ật vị trí vtmin nh min 10 1 5 7 2 3 3 4 15 9 5 1 6 2 7 8 22 Bư c 2: So sánh giá trị tại vtmin với tất c giá trị tại vị trí c n lại (từ 2 đến 8), nếu c 7 lớn hơn 5 phần tử nào nhỏ hơn phần tử tại vtmin thì nên không c p nhvtminlại vtmin c p nhật vị ật trí min 10 1 5 7 2 3 3 4 15 9 5 1 6 2 7 8 23 Bư c 2: So... tất c giá trị tại vị trí c n lại (từ 2 đến 8), nếu c 3 nhỏ hơn 5 phần tử nào nhỏ hơn phần tử tại vtmin thì nên c p c p nhvtminlại vtmin ật nhật vị trí min 10 1 5 7 2 3 3 4 15 9 5 1 6 2 7 8 24 Bư c 2: So sánh giá trị tại vtmin lvới hơn 3ả tất c 9 ớn giá trị tại vị trí c n lại (từ 2 đến 8),không c nên nếu phần tử nào nhỏ hơn phần tử tcậpvtmin vị ại nhật thì c p nhật lại vtmin trí min vtmin 10 1 5 7... XuatMang(int a[], int n) { for(int i=0; i . ̣̀ * Ca c tha nh phâ n cua mang la tâp h p ca c biê n co cu ng ́ ̀ ̀ ̀ ́ ́ ́ ̀̉ ̉ ̣ ợ kiêu d liêu va cu ng tên. Do đo đê truy xuâ t ca c biê n ̃ ̀ ̀ ́ ́ ́ ́̉ ư ̣ ̉ tha nh phâ n, ta du ng c chê chi. * CH NG 5 Ơ M NG M T CHI UẢ Ộ Ề 9 / 4 / 1 5 1 9/4/ 15 2 * KHÁI NI MỆ * Mang th c châ t la môt biê n đ c câ p pha t bô nh liên ́ ̀ ́ ́ ́ ́̉ ự ̣ ượ ̣ ơ tuc va bao gô m nhiê u. phần tử tối đa của mảng> ] ; Nh m thu n ti n cho vi c vi t ch ng trình, ta nên đ nh ằ ậ ệ ệ ế ươ ị nghĩa h ng s MAX đ u ch ng trình – là kích th c t i đa ằ ố ở ầ ươ ướ ố c a m ng - nh sau:ủ