Bài 8. Lắp với số lần chưa biết trước. - Pdf 15

Trêng THCS S¬n TiÕn Gi¸o viªn: Ph¹m TuÊn Anh
Dạy Lớp: 8B; 8C; 8D. Ngày soạn: 11/01/2009.
Tiết PPCT: 41 + 42. Ngày dạy: /01/2009.
Bài 8. Lặp với số lần chưa biết trước
I.Mục tiêu::
+ Biết nhu cầu cần có cấu trúc lặp với số lần chưa biết trước trong ngôn ngữ lập trình;
+ Biết ngôn ngữ lập trình dùng cấu trúc lặp với số lần chưa biết trước để chỉ dẫn máy
tính thực hiện lặp đi lặp lại công việc đến khi một điều kiện nào đó được thoả mãn;
+ Hiểu hoạt động của câu lệnh lặp với số lần chưa biết trước while do… trong Pascal.
II. Chuẩn bị
GV: SGK, máy chiếu, phim trong các ví dụ về chương trình
HS: Xem trước bài ở nhà
III. Tiến trình bài giảng
1. Ổn định ớp
2. Kiểm tra bài củ
Viết thuật toán tính tổng 100 số tự nhiên đầu tiên 1,2,3,…,99,100
Trả lời
Bước 1. SUM ← 0; i ← 0.
Bước 2. i ← i + 1.
Bước 3. Nếu i ≤ 100, thì SUM ← SUM + i và quay lại bước 2.
Bước 4. Thông báo kết quả và kết thúc thuật toán.
G : Đặt vấn đề
Với bài toán trên, trong TP ta sử dụng vòng lặp for…to…do thì sẽ thực hiện dễ
dàng . Nhưng nếu ta thay số 100 bởi n ( tính tổng n số tự nhiên đầu tiên ) thì ta sẽ gặp
nhiều khó khăn trong việc sử dụng vòng lặp for…to…do bởi lúc này số lần lặp không
biết trước. Vậy ta phải làm như thế nào ? Giới thiệu bài mới .
3. Bài mới
Hoạt động của thầy và trò Ghi bảng
+ G : y/c hs đọc ví dụ 1sgk/67
+ Hs : 2-3 hs đọc ví dụ sgk
+ G : Phân tích ví dụ

trong các chương trình lập
trình . Sau đây ta xét câu lệnh và
ví dụ trong TP
+ G : Giới thiệu cú pháp lệnh
while … do ….;
+ hs : chú ý nghe và ghi chép
Giải :
Kí hiệu S là tổng cần tìm và ta có thuật toán như
sau:
+ Bước 1. S

0, n

0.
+ Bước 2. Nếu S ≤ 1000, n

n + 1; ngược lại
chuyển tới bước 4.
+ Bước 3. S

S + n và quay lại bước 2.
+ Bước 4. In kết quả : S và n là số tự nhiên nhỏ
nhất sao cho S > 1000. Kết thúc thuật toán.
* Ta có sơ đồ khối :

* Nhận xét : Để viết chương trình chỉ dẫn máy
tính thực hiện các hoạt động lặp như trong các ví
dụ trên, ta có thể sử dụng câu lệnh có dạng lặp
với số lần chưa biết trước
2. Ví dụ về lệnh lặp với số lần chưa biết trước

+ G : Chạy tay cho học sinh
xem
+ Hs : chú ý nghe và tự chạy tay
lại
+ G : Yêu cầu học sinh mở máy
tính và mở chương trình ví dụ 3
( giáo viên chuẩn bị chương
trình mẫu và đưa lên các máy )
+ Hs : thực hiện
+ G : Cho học sinh chạy chương
trình trên máy
+ Hs : thực hiện
+ G : Yêu cầu hs thay điều kiện
sai_so = 0.003 thành 0.002 ;
0.001 ; 0.005 ;
+ Hs : thực hiện
Câu lệnh lặp này được thực hiện như sau:
Bước 1 : Kiểm tra điều kiện.
Bước 2 : Nếu điều kiện SAI, câu lệnh sẽ bị bỏ
qua và việc thực hiện lệnh lặp kết thúc. Nếu điều
kiện đúng, thực hiện câu lệnh và quay lại bước 1.
Ví dụ 3.
Với giá trị nào của n ( n>o ) thì
1
n
< 0.005 hoặc
1
n
< 0.003? Chương trình dưới đây tính số n nhỏ
nhất để

+ G : Chạy tay cho học sinh
xem
+ Hs : chú ý nghe và tự chạy tay
lại
+ G : Yêu cầu học sinh mở máy
tính và mở chương trình ví dụ 4
( giáo viên chuẩn bị chương
trình mẫu và đưa lên các máy )
+ Hs : thực hiện
+ G : Cho học sinh chạy chương
trình trên máy
+ Hs : thực hiện
+ G : chạy chương trình này, ta
nhận được giá trị ntn?
+ Hs : Nếu chạy chương trình
này ta sẽ nhận được n = 45 và
tổng đầu tiên lớn hơn 1000 là
1034.
+ G : giới thiệu ví dụ 5 sgk
Viết chương trình tính tổng
1 1 1
1
2 3 100
T
= + + + +
+ G : Cho học sinh quan sát
phim trong chương trình
+ Hs : quan sát
+ G : Chạy tay ( cả hai chương
trình ) cho học sinh xem

với số lần lặp biết trước for…do:
T:=0;
for i:=1 to 100 do T:=T+1/i;
writeln(T);
Nếu sử dụng lệnh lặp while…do, đoạn chương
trình dưới đây cũng cho cùng một kết quả:
T:=0;
i:=1;
while i<=100 do begin T:=T+1/i; i:=i+1 end;
writeln(T);
* Nhận xét : Ví dụ này cho thấy rằng chúng ta có
Gi¸o ¸n tin häc líp 8.
Trêng THCS S¬n TiÕn Gi¸o viªn: Ph¹m TuÊn Anh
+ G : Ví dụ này cho thấy rằng
chúng ta có thể sử dụng câu
lệnh while…do thay cho câu
lệnh for…do.
+ G : Giới thiệu phần 3
+ G : Khi viết chương trình sử
dụng cấu trúc lặp cần chú ý
tránh tạo nên vòng lặp không
bao giờ kết thúc
+ Hs : Chú ý nghe
+ G : Chẳng hạn, chương trình
dưới đây sẽ lặp lại vô tận:
var a:integer;
begin
a:=5;
while a<6 do writeln('A');
end.


Nhờ tải bản gốc

Tài liệu, ebook tham khảo khác

Music ♫

Copyright: Tài liệu đại học © DMCA.com Protection Status