Bài giảng Tin học Lớp 8 - Bài 9: Làm việc với dãy số

pptx 24 trang phanha23b 26/03/2022 4480
Bạn đang xem 20 trang mẫu của tài liệu "Bài giảng Tin học Lớp 8 - Bài 9: Làm việc với dãy số", để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên

Tài liệu đính kèm:

  • pptxbai_giang_tin_hoc_lop_8_bai_9_lam_viec_voi_day_so.pptx

Nội dung text: Bài giảng Tin học Lớp 8 - Bài 9: Làm việc với dãy số

  1. Tin Học 8
  2. KiÓm tra bµi cò Dữ liệu mảng và biến của mảng gọi là gì ? - D÷ liÖu kiÓu m¶ng: lµ mét tËp hîp c¸c phÇn tö cã thø tù, vµ mäi phÇn tö ®Òu cã cïng mét kiÓu d÷ liÖu - Biến mảng: khi khai báo một biến có kiểu dữ liệu là kiểu mảng, biến đó được gọi là biến mảng.
  3. Bài 9: 2. Ví dụ về biến mảng a.Cách khai báo mảng trong Pascal: Var Tên mảng : array [ ] of ; Tuoi 7 6 8 9 . 10 Chỉ số 1 2 3 4 . 40 Var Tuoi : array[1 40] of Integer; Chieuc 1.5 1.65 1.75 1.7 . 1.8 Chỉao số 2 3 4 5 . 20 Var chieucao: array[2 20] of Real;
  4. Bài 9: 2. Ví dụ về biến mảng a. Khai báo mảng một chiều trong Pascal: Var Tên mảng : array[ ] of ; Trong đó: - Tên mảng: Do người lập trình đặt - array, of: Là từ khóa của chương trình - Chỉ số đầu, chỉ số cuối: Là 2 số nguyên, thỏa mãn: chỉ số đầu ≤ chỉ số cuối giữa hai chỉ số là dấu - Kiểu dữ liệu: Là kiểu của các phần tử, là Integer hoặc Real - Số phần tử = chỉ số cuối – chỉ số đầu + 1
  5. Bài 9: 2. Ví dụ về biến mảng a) Cách khai báo mảng trong Pascal: Ví dụ: Cách khai báo đơn giản một biến mảng trong ngôn ngữ Pascal như sau: var Tuoi: array[21 80] of integer; Tên biến Số lượng phần tử Kiểu dữ liệu chung var Chieucao: array[1 50] of real; Chỉ số đầu Chỉ số cuối
  6. Bài 9: 2. Ví dụ về biến mảng a) Cách khai báo mảng trong Pascal: Var Tênmảng: array [ ] of ; Ví dụ: Hãy khai báo các mảng sau: 1/ Mảng Diem gồm 40 phần tử thuộc kiểu dữ liệu số thực? Var diem : array[1 40] of real; 2/ Mảng A, B gồm 10 phần tử thuộc kiểu dữ liệu số nguyên? Var A: array[1 10] of integer; Var A ,B: array[1 10] of integer; B: array[1 10] of integer;
  7. Bài 9: 2. Ví dụ về biến mảng a) Cách khai báo mảng trong Pascal: Câu lệnh khai báo biến mảng sau đây máy tính có thực hiện được không? Var N : integer; Không xác định A : array[1 N] of real; KHÔNG Lưu ý: - Kích thước của mảng phải được khai báo bằng một con số cụ thể
  8. Bài 9: Lưu ý: Kích thước của mảng phải được khai báo bằng một con số cụ thể
  9. Bài 9: 2. Ví dụ về biến mảng a) Cách khai báo mảng trong Pascal: Tênmảng: array [ ] of ; b) Truy cập đến giá trị phần tử trong mảng: Cú pháp: Tên mảng [Chỉ số] VD: DiemTin[1] → Tham chiếu tới phần tử thứ nhất của mảng DiemTin
  10. Bài 9: 2. Ví dụ về biến mảng b) Truy cập đến giá trị phần tử trong mảng: Cú pháp: Tên mảng [Chỉ số] Ví dụ1: Cho mảng A chứa các giá trị sau: 2 5 7 1 10 3 4 5 6 7 - Xác định các giá trị của: A[1], A[3], A[5], A[10] ? A[1], A[10]: không xác định A[3]=2; A[5]=4
  11. Bài 9: 2. Ví dụ về biến mảng b) Truy cập đến giá trị phần tử trongCó thểmảng thực: hiện các thao tác nào với các phần tử trong mảng? Cú pháp: Tên mảng [Chỉ số] Ví dụ 2: Cho các câu lệnh sau: A[3]:=2; A[3]=2 A[4]:=5; A[4]=5 A[6]:=A[3]+A[4]; A[6]=7 Giá trị của các phần A[3], A[4], A[6] sẽ là bao nhiêu? - Có thể gán giá trị, đọc giá trị và thực hiện tính toán với các phần tử trong mảng
  12. Bài 9: 2. Ví dụ về biến mảng b) Truy cập đến giá trị phần tử trong mảng: Ví dụ: Gán giá trị cho 40 phần tử của mảng DiemTin DiemTin[1]:=5; DiemTin[2]:=7; DiemTin[40]:=10; Viết chương trình khá dài Hoặc Readln(DiemTin[1]); For i:=1 to 40 do Readln(DiemTin[i]); Readln(DiemTin[2]); Readln(DiemTin([40]); For i := to do Readln(Tenmang[i]);
  13. Bài 9: 2. Ví dụ về biến mảng c. Nhập giá trị cho mảng A 7 5 8 6 9 10 9 với nn = 7 - Sử dụng lệnh Read (Readln) kết hợp với For do. Các bước Thể hiện bằng pascal Write(‘ Nhap vao so HS:’); 1. Nhập số phần tử của mảng. Readln(n); For i:=1 to n do 2. Nhập vào giá trị từng phần tử Begin của mảng (A[i]). write(‘Diem cho HS thu ’ ,i, ’ : ’); Sử dụng cấu trúc readln(A[i]); lặp để nhập dữ liệu end;
  14. Bài 9: 2. Ví dụ về biến mảng d. In giá trị các phần tử của mảng: Ví dụ: In giá trị của 40 phần tử trong mảng DiemTin For i:=1 to 40 do Writeln(DiemTin[i]); DiemTin 88 6 7 66 . . . . Chỉ số 1 2 3 4 . i . 40 DiemTin[1] = 8 DiemTin[4] = 6 For i:= to do Writeln(Tenmang[i]);
  15. Bài 9: 2. Ví dụ về biến mảng d. In giá trị các phần tử của mảng: Sử dụng lệnh Write (Writeln) kết hợp với For do. - Thông báo Writeln(‘ Điểm của lớp : ’); - In giá trị của For i:=1 to n do từng phần tử Write(A[i]:7); - Sử dụng cấu trúc lặp để in dữ liệu Kết quả trên màn hình: Điểm của lớp: 7 5 8 6 9 10 9
  16. Bài 9: 3. Tìm giá trị lớn nhất và giá trị nhỏ nhất của dãy số: Bài toán: Viết chương trình nhập N số nguyên từ bàn phím và in ra màn hình số nhỏ nhất và số lớn nhất. THUẬT TOÁN • B1: max:=a; min:=a;Em hãy i:=1; nêu • B2: i:= i+1; thuật toán để tìm số nhỏ nhất và • B3: Nếu i > n,số chuyển lớn nhất đến trong bước 5. dãy số? • B4: Nếu ai > max thì max:=ai; ai < min thì min :=ai.Quay lai bước 2. • B5: Kết thúc thuật toán.
  17. Program vd1; Uses crt; Var i, n, Max, Min: integer ; Khai báo biến mảng A: Array[1 100] of Integer ; BEGIN Clrscr; write(‘ Nhap so phan tu cua day so: n= ’) ; readln(n) ; For i := 1 to n do Begin Nhập giá trị cho mảng write(‘ Nhap so thu ‘,i,’ : ‘) ; readln(A[i]) ; End; Max:=A[1]; For i := 2 to n do If A[i]>Max Then Max := A[i]; Writeln(‘ So lon nhat la max = ', Max) ; Min:=A[1]; For i := 2 to n do Tìm số lớn nhất và nhỏ If A[i]<Min Then Min := A[i]; nhất Writeln(‘ So nho nhat la Min = ', Min) ; Readln ; END.
  18. Ch¬ng tr×nh ch¹y vµ cho kÕt qu¶ nh sau: Nhap so phan tu cua day so: n= 7 Nhap so thu 1 : 7 Nhap so thu 2 : 9 Nhap so thu 3 : 4 Nhap so thu 4 : 6 Nhap so thu 5 : 9 Nhap so thu 6 : 8 Nhap so thu 7 : 5 So lon nhat la Max = 9 So nho nhat la Min = 4
  19. Kiến thức cần nhớ Củng cố
  20. Bài 9: Bài tập củng cố Bài 1: Em hãy chọn đáp án đúng: A. Dữ liệu kiểu mảng là tập hợp các phần tử không có thứ tự và mọi phần tử có cùng một kiểu dữ liệu. B. Dữ liệu kiểu mảng là tập hợp các phần tử có thứ tự và mỗi một phần tử trong mảng có thể có các kiểu dữ liệu khác nhau . C. Dữ liệu kiểu mảng là tập hợp các phần tử có thứ tự và mọi phần tử có cùng một kiểu dữ liệu.
  21. Bài 9: Củng cố Bài 2: Cách khai báo biến mảng sau đây đúng hay sai? Khoanh tròn vào chỗ sai (nếu có). a) Var X: Array[10 , 13] of Real; a) Sửa dấu , thành dấu b) Var X: Array[3 4.8] of Integer; b) Sửa 4.8 thành số nguyên c) Var X: Array[10 1] of Integer; c) Chỉ số cuối phải >= chỉ số đầu d) Var X: Array[4 10] of Real; d) Đúng
  22. 1 V A R 2 R E A D 3 R E A L 4 M A X 5 N G U Y Ê N Có CóCó6 chữ 44 Cóchữchữ cái: 3 cái: cái: chữChỉ Là Là cái:số câu từđầu, Là khóa lệnh từchỉ khóa trong trongsố cuối để chương chương khai trong báo trìnhkhai trình biến báoPascal Pascal mảng Có 3 chữ cái: Là tên của hàm tìm giá trị lớn nhất? dùng để dùngdừngThường đểchươngtrong thể là chươnghiện những trình những chờ trìnhsố .? tabiến Pascal? nhập kiểu giá thực? trị cho biến?
  23. Bài 9: - Học bài cũ - Tìm hiểu thuật toán tìm giá trị lớn nhất, nhỏ nhất của dãy số (xem lại ví dụ 6 trang 43 SGK) - Về nhà làm các bài tập 2, 4, 5 trang 79 SGK
  24. Xin chân thành cảm ơn sự chú ý theo dõi của các học sinh