1. Trang chủ
  2. » Giáo án - Bài giảng

Bồi dưỡng học sinh giỏi tin học 8

103 660 3

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 103
Dung lượng 390,5 KB

Nội dung

Bài 2 :Viết chương trình đếm số lần xuất hiện của các kí tự thuộc bảng chữ cái trong 50 lần gõ kí tự bằng bàn phím không phân biệt a với A, b với B …, dùng hàm Upcase để chuyển đổi chữ

Trang 1

CHUYÊN ĐỀ HỌC SINH GIỎI TIN 8

CÂU LỆNH IF … THEN … ELSE

Bài 1 :Nhập 3 số a , b , c bất kì Hãy kiểm tra xem ba số đó có thể là độ dài ba cạnh của

một tam giác hay không ? Thông báo lên màn hình ‘ Thỏa mãn ‘, ‘ Không thỏa mãn trongtừng trường hợp tương ứng

Đếm các số lớn hơn 10 và nhỏ hơn 20 và tính tổng của chúng Sau đó , đưa ra màn hình :

So cac so >10 và <20 la : ( gia tri )

Tong cua chung la : ( gia tri )

2) Var

Trang 2

Tong , So : Real ; I , N , Dem : Integer ;

Bài 3 :Nhập bốn số a , b , c , d Hãy tìm giá trị lớn nhất của chúng và gán giá trị lớn nhất

đó cho biến Max

3) Var

Max , a , b , c , d : Real ;

BEGIN

Writeln (' Nhap gia tri cua 4 so : ') ;

Write (' a = ') ; Readln ( a ) ; Write (' b = ') ; Readln ( b ) ; Write (' c = ') ; Readln ( c) ; Write (' d = ') ; Readln ( d ) ;

Max := a ;

Trang 3

If Max < b Then Max := b ; If Max < c Then Max := c ; If Max < d Then Max :=

Write (' Doc Ngay Thang Nam : ') ; Readln ( Ngay , Thang , Nam ) ;

Nam := 1900 + ( Nam mod 1900 ) ;

Trang 4

Bài 5 :Viết chương trình :

Nhâp số báo danh

Nhập điểm văn , toán , ngoại ngữ

Write (' So bao danh : ') ; Readln( SBD ) ; Write (' Diem toan : ') ; Readln( Toan ) ;

Write (' Diem ngoai ngu : ') ; Readln( Ngoaingu ) ; Write (' Diem van : ') ; Readln ( Van ) ;

Tongdiem := Toan + Van + Ngoaingu ;

Clrscr ;

Writeln (' Phieu Bao Diem ') ;

Writeln (' So bao danh : ', SBD ) ; Writeln (' Diem van : ', Van ) ;

Writeln (' Diem toan : ', Toan ) ; Writeln (' Diem ngoai ngu : ', Ngoaingu) ; Writeln (' Tong diem : ', Tongdiem) ;

If Tongdiem >= 15 Then

Writeln(' Ban da trung tuyen ') Else Writeln(' Ban khong trung tuyen ') ;

Readln ;

Trang 5

END

Bài 6 :Viết chương trình nhập hai số thực Sau đó hỏi phép tính cần thực hiện và in kết

quả của phép tính đó

Nếu là “+” , in kết quả của tổng lên màn hình

Nếu là “-” , in kết quả của hiệu lên màn hình

Nếu là “/” , in kết quả của thương lên màn hình

Nếu là “*” , in kết quả của tích lên màn hình Nếu là “+” , in kết quả của tổng lên màn hình

Nếu là “+” , in kết quả của tổng lên màn hình

Write (' a = ') ; Readln( a ) ; Write (' b = ') ; Readln( b ) ;

Write (' Phep tinh thuc hien la (+ - * /) : ') ;

Trang 6

Bài 7 :Giải và biện luận phương trình : x2 + ( m – 2 ) x + 1 = 0 ở đây m là tham số thực tuỳ ý

Writeln(' Phuong trinh co 2 nghiem : ') ;

Writeln (' X1 = ', ( -(m-2) + sqrt(delta) ) / 2 ) ; Writeln (' X2 = ', ( -(m-2) - sqrt(Delta) ) / 2 ) ;

End ;

End ;

Readln ;

END

Bài 8 :Viết chương trình nhập hai số tự nhiên N, M và thông báo ‘Dung‘ nếu N , M cùng

tính chẵn lẽ , trong trường hợp ngược lại thì thông báo ‘Sai‘

8) Uses Crt ;

Var

Trang 7

Bài 1 :Lập trình tính tích các số tự nhiên từ 1 tới 10

Bài 2 :Viết chương trình đếm số lần xuất hiện của các kí tự thuộc bảng chữ cái trong 50

lần gõ kí tự bằng bàn phím (không phân biệt a với A, b với B …, dùng hàm Upcase để chuyển đổi chữ thường với chữ hoa)

Bài 3 :Cho số tự nhiên n , hãy lập trình để tính các tổng sau :

ở đây n là số tự nhiên được nhập vào từ bàn phím

Bài 6 :Tính hàm lũy thừa an , ở đây a thực và n tự nhiên được nhập vào từ bàn phím

Bài 7 :Viết chương trình nhập một dãy số tối đa 100 số , sau đó in ra màn hình các số

khác nhau

Trang 8

Bài 8 :Viết chương trình nhập một dãy số tối đa 100 số , sau đó sắp xếp lại theo thứ tự tăng dần

Bài 11 :Bạn có 1000 đ đem gửi ngân hàng với lãi suất 8%/tháng Sau mỗi tháng tiền lãi

được nhập vào để tính lãi suất tháng sau Bạn muốn để dành cho đến khi số tiền tăng lên

là x Vậy phải để trong bao lâu

Bài 12 :Viết chương trình tìm ƯSCLN của N số được nhập từ bàn phím

1)Var i : Byte ; (* chỉ số chạy *)

p : word ; (* tích số *)

BEGIN

p := 1; (* cho giá trị ban đầu của tích *)

For i := 1 to 10 Do (* cho i chạy từ 1 tới 10 *)

p := p * i ; (* lần lượt nhân i với p *)

Trang 9

i : byte ; (* chỉ số của lần gõ phím *)

BEGIN

Clrscr ;

For ch :='A' to 'Z' Do a[ch] := 0 ; (* xả bộ đếm *)

Writeln (' Go phim 50 lan ') ;

For i := 1 To 50 Do (* thực hiện 100 lần *)

Begin

ch :=Readkey ; (* nhập kí tự vào Ch không cần gõ Enter *)

ch := Upcase(ch) ; (* Đỗi chữ thường thành chữ hoa *) a[ch] := a[ch] + 1 ;

End;

Writeln (' So lan xuat hien cac ki tu la :') ;

For ch :='A' to 'Z' do (* Kiểm tra bộ đếm từ 'A' tới 'Z' *)

If a[ch] > 0 Then (* Nếu Ch có xuất hiện *)

Writeln (ch , a[ch] : 4 , ' lan ') ; (* Viết ra màn hình kí tự và

Trang 10

Write (' Nhap n : ') ; Readln (n) ;

Trang 11

Begin

Write(' Nhap n : ') ; Readln (n) ;

p := 1 ;

For i := 1 To n Do p := p * ( 1 + 1/sqr(i) ) ; Writeln(' p = ', p:10:5 ) ;

Trang 13

While ( j < i ) and ( A[j] <> A[i] ) Do inc(j) ;

If j = i Then Writeln( A[i] ) ;

Trang 14

Write(' Do dai cua day so N = ') ; Readln (N) ; Writeln (' Nhap day so : ') ;

Trang 15

Write (' Nhap so thuc a : ') ; Readln(a) ;

Writeln (' Cac phan tu lon hon a cua day : ') ;

Trang 16

Write (' Nhap do dai cua day so nguyen : ') ; Readln(n) ;

Writeln (' Nhap cac phan tu cua day : ') ;

Trang 19

writeln (' Ban phai gui tien trong ', thang div 12 , ' nam ',

thang mod 12 ,' thang ') ;

writeln (' Khi do so tien ban rut ra duoc la ', tien:12:2 ,' dong ') ; readln ;

Writeln (' Tim USCLN cua N so :') ;

Write (' Nhap so N : ') ; Readln(n) ;

Trang 20

Bài 1 :Dùng thủ tục chuyển một số tự nhiên n cho trước sang hệ cơ số 2

Bài 2 :Dùng thủ tục giải phương trình bậc hai ax2 + bx + c = 0

Bài 3 :Hãy viết lại thủ tục Insert đối với một chuỗi kí tự cho trước tùy ý

Bài 4 :Viết chương trình thực hiện lần lượt các công việc sau :

_ Lập thủ tục nhập ba số thực dương a , b , c từ bàn phím

_ Lập thủ tục kiểm tra xem ba số trên có lập thành ba cạnh của tam giác hay không ? _ Viết thủ tục tính diện tích của tam giác

_ Viết thủ tục tính các trung tuyến của tam giác

_ Viết hoàn thiện chương trình chính

Bài 5 :Giải phương trình x + y + z = 12 trong phạm vi số nguyên không âm với điều kiện

x < 4

Bài 6 :Cho trước các số N , a , b , c tự nhiên Giải phương trình sau trong phạm vi số

nguyên không âm x + y + z = N với điều kiện x < a , y < b , z < c

Bài 7 :Viết thủ tục Compare ( S1 , S2 : String ; Var Kq : String ) thực hiện công việc

sau : so sánh hai xâu S1 và S2 , tìm tất cả các kí tự có trong cả hai xâu trên Xâu Kq sẽ

chứa tất cả các kí tự đó , mỗi kí tự chỉ được nhớ một lần

Bài 8 :Viết hàm tính D (St1 , St2) , với U, V là hai xâu kí tự bất kì , là tổng số các kí tự

không giống nhau trong hai xâu trên , mỗi loại kí tự chỉ được nhớ một lần Ví dụ D (‘aabba’ , ‘bcdd’) = 2 vì chỉ có hai kí tự a và d là không giống nhau trong các xâu trên

Bài 9 :Viết chương trình hoàn chỉnh thực hiện các công việc của thực đơn sau :

Trang 21

1 Nhập dữ liệu ( nhập số tự nhiên n )

2 Phân tích ra thừa số nguyên tố ( phân tích n thành tích các số nguyên tố )

3 Thoát khỏi chương trình

CẤU TRÚC DỮ LIỆU KIỂU MẢNG

Bài 1 :Giải hệ phương trình tuyến tính hai ẩn dùng ma trận :

a11x + a12y = c1

a21x + a22y = c2

Bài 2 :Lập phương trình tạo ra một mảng chứa bảng cửu chương

Bài 3 :Viết chương trình nhập hai số nguyên dương m , n Sau đó tính trung bình cộng bình phương các số nguyên từ m đến n

Bài 4 :Viết chương trình nhập từ bàn phím các phần tử của một mảng hai chiều Kích thước của mảng được nhập trước từ bàn phím

Bài 5 :Dãy số sau được gọi là dãy Fibonaci :

Trang 22

an = 2an-1 + an-2 ( n > 2 )

Hãy lập chương trình tính và gán giá trị của dãy vào biến mảng

Bài 7 :Nhập số tự nhiên N và viết chương trình tạo mảng bao gồm N số nguyên tố đầu tiên

Bài 8 :Viết chương trình nhập một bảng số 3 x 3 với điều kiện các số được nhập sẽ hiện trên màn hình đúng tại vị trí của mình trên bảng số

Bài 9 :a Viết chương trình nhập dữ liệu từ dãy đối xứng vào mảng một chiều

b Viết chương trình nhập dữ liệu là ma trận đối xứng vào mảng hai chiều

b Mỗi một nhóm các dấu chấm liền nhau bằng một dấu chấm

c Một nhóm các dấu chấm đứng liền nhau bằng dấu ba chấm

Bài 3 :Cho số tự nhiên n và một dãy các kí tự S1 , S2 , … , Sn Hãy tìm số tự nhiên I đầu tiên sao cho các kí tự Si , Si+1 đều là chữ cái a Nếu trong dãy không có những cặp như vậy thì thông báo

Bài 4 :Cho số tự nhiên n và dãy các kí tự S1 , S2 , … , Sn Biết rằng trong dãy có ít nhất một dấu phẩy Hãy tìm số tự nhiên i sao cho :

a Si là dấu phẩy đầu tiên b Si là dấu phầy cuối cùng

Bài 5 :Viết chương trình nhập một xâu kí tự , sau đó chỉ ra xem xâu đó có phải là xâu đối

xứng không ( xâu đối xứng là xâu có các kí tự giống nhau và đối xứng nhau qua điểm

giữa xâu , ví dụ ‘ABBA’ hoặc ‘ABCBA’ )

Bài 6 :Cho một xâu kí tự S Hãy viết chương trình tính xem trong S có bao nhiêu loại kí

tự khác nhau ( phân biệt chữ in hoa với chữ in thường ) Ví dụ với S là “Pascal” ta có đáp số là 5

Bài 7 :Viết chương trình nhập một xâu kí tự và biến đổi chúng thành toàn chữ in hoa

Trang 23

Bài 8 :Họ tên một học sinh được nhập từ bàn phím Bạn hãy viết chương trình điều chỉnh lại các kí tự đầu của các từ đơn trong tên của học sinh ấy trở thành chữ in hoa

Bài 9 :Viết chương trình nhập xãu kí tự từ bàn phím , sau đó gọt xâu lại bằng cách cách

xoá đi các kí tự trống ở hai đầu của xâu Ví dụ nếu nhập xâu “ Ha noi “ , thì kết quả sẽ là

“Ha noi”

D÷ LIƯU KIĨU TƯP

Bài 1 :Bạn hãy viết hàm Card(A) đếm số phần tử của tập hợp A cho trước có kiểu Set Of

0 99

Bài 2 :Bạn hãy lập chương trình tạo một tập hợp các số nguyên chẵn kiểu Byte và loại

khỏi nó các số chia hết cho 3 Kết quả thể hiện trên màn hình

Bài 3 :Xét chương trình sau :

Hãy tìm và sửa lỗi trong chương trình đó

Bài 4 :Bạn hãy lập chương trình hiển thị một menu dạng sau trên màn hình

1 Xem

2 Sua chua

3 Loai bo

4 Nhap them

Trang 24

5 Thoat

Lua chon cua ban : _

Sau đó đợi gõ phím Chương trình phải đợi cho tới khi phím gõ vào là một trong các chữ

số 1 5 hoặc các chữ cái đầu của các tuỳ chọn thì thông báo phím gõ vào hợp lệ và kết thúc chương trình Trong chương trình phải dùng một tập hợp để kiểm tra việc nhập giá

trị cho biến từ bàn phím

Bài 5 :Hãy lập chương trình nhập vào một xâu nhị phân Các kí tự nhập vào không hợp

lệ bị bỏ qua

Bài 6 :Hãy lập chương trình nhập vào một xâu kí tự từ bàn phím Yêu cầu các kí tự nhập

vào phải là các chữ cái thuộc bảng chữ cái tiếng Anh , bỏ qua các phím khác

Bài 7 :Viết chương trình có chức năng thêm phần tử vào tập hợp trực tiếp từ bàn phím và

loại bớt phần tử khỏi tập hợp cũng trực tiếp từ bàn phím

CU TRĩC D÷ LIƯU KIĨU RECORD

Bài 1 :Thông tin về mỗi học sinh gồm :

• Họ đệm : một xâu 25 kí tự

• Tên : một xâu 10 kí tự

• Tuổi : một số nguyên hai chữ số

• Lớp : một xâu hai chữ số và một chữ cái viết hoa

Hãy lập chương trình nhập từ bàn phím danh sách một lớp 15 học sinh vào một mảng bản

ghi Sau đó hiển thị danh sách lên màn hình , mỗi người một dòng

Bài 2 :Thông tin về mỗi học sinh là một bản ghi gồm các trường :

• Họđệm : một xâu 25 kí tự

• Tên : một xâu 10 kí tự

• Tuổi : một số nguyên hai chữ số

• Lớp : một xâu hai chữ số và một chữ cái viết hoa

Một file bản ghi chứa một danh sách một lớp gồm 20 học sinh Hãy lập chương trình

hiển thị danh sách lên màn hình , mỗi người một dòng

Trang 25

Bài 3 :Một file bản ghi chứa một danh sách học sinh , thông tin về mỗi học sinh giống

như bài trên Hãy lập chương trình tạo một file bản ghi khác chứa danh sách đó , mỗi bảnghi gồm các trường :

• Họtên : một xâu 35 kí tự

• Tuổi : một số nguyên hai chữ số

• Khối : một số nguyên hai chữ số

• Lớp : một chữ cái viết hoa

Bài 4 :Một file bản ghi chứa một danh sách học sinh PTTH , thông tin về mỗi học sinh

ngoài các trường Họđệm , Tên , Tuổi , Lớp giống như các bài trên còn có thêm trường Điểm chứa điểm trung bình của học sinh trong năm học Hãy lập chương trình :

a Hiển thị lên màn hình danh sách những học sinh giỏi nhất của trường là những bạn có

điểm trung bình từ 8.0 trở lên và cao nhất trong khối

b Lập danh sách học sinh trong năm học mới , biết một học sinh có điểm trung bình từ

5.0 trở lên thì được lên lớp Chú ý : lớp 10A lên lớp 11A , lớp 11A lên 12A Kết quả

chứa trong file

Bài 5 :Cho file bản ghi f chứa dữ liệu về kho sách , dữ liệu về mỗi cuốn sách được chứa

trong một bản ghi gồm 3 trường mang thông tin về :

• Họ tên tác giả : một xâu 26 kí tự

• Tên sách : một xâu 40 kí tự

• Năm xuất bản : một số nguyên 4 chữ số

Hăy lập chương trình nhập dữ liệu vào kho sách , sau đó tìm ra :

• Những cuốn sách của một tác giả cho trước xuất bản vào một năm cho trước

• Những cuốn sách có tên cho trước

Kết quả hiện trên màn hình

Bài 6 :

File bản ghi F chứa danh sách các ngày lễ trong một năm , mỗi bản ghi gồm ngày tháng , tên ngày lễ và số ngày được nghỉ Hãy lập chương trình nhập danh sách các ngày lễ và tính :

Trang 26

• Tổng số các ngày lễ và tổng số các ngày nghỉ lễ trong năm

• Tổng số các ngày lễ và tổng số các ngày nghỉ lễ trong quí 1 , quí 2 , …

Kết quả thể hiện trên màn hình

CU TRĩC D÷ LIƯU KIĨU FILE

Bài 1 :Hãy lập chương trình tạo một tệp số nguyên chứa các số nguyên tố nhỏ hơn 10000

theo thứ tự tăng dần

Bài 2 :Cho f là tệp văn bản chứa các xâu 10 kí tự Hãy lập chương trình nhập và hiển thị

nội dung file đó lên màn hình , mỗi xâu một dòng , đầy trang màn hình thì dừng lại đợi

gõ Enter mới hiển thị trang tiếp theo cho tới hết

Bài 3 :Bạn hãy viết chương trình cho phép đọc dữ liệu từ bàn phím và ghi thêm vào cuối

một tệp các bản ghi

Bài 4 :Cho một văn bản chứa trong một text file f Trong văn bản , tính từ trái sang phải ,

từ trên xuống dưới , kí tự # là kí hiệu xoá đi một từ đứng ngay trước nó nếu có Ví dụ

‘#Ta#oi di ngu#h###hoc’ có nghĩa là ‘Toi di hoc’ Bạn hãy viết chương trình sửa lại file

f theo quy ước trên

Bài 5 :Cho 2 file f và g cùng kiểu ( nhưng không rõ kiểu nào ) Bạn hãy lập thủ tục gán

nội dung của file g cho file f

Bài 6 :Cho một file text ghi lại một chương trình Pascal của một học sinh Hãy viết

chương trình kiểm tra lỗi của chương trình Pascal trên theo các cách sau đây :

Cách 1 : Kiểm tra xem số lượng các dấu ‘ ( dấu mở và dấu đóng ) có bằng nhau không ?Cách 2 : Kiểm tra xem số lượng các từ Begin và End có bằng nhau không ?

Bài 7 :Cho một file text Hãy viết chương trình đếm xem file text trên chứa bao nhiêu

từ ( Chú ý : theo quy định , các từ cách nhau bởi một hay nhiều dấu cách )

Bài 8 :Cho một file text Viết chương trình loại bỏ các khoảng trống thừa bên trong file

text này

CU TRĩC D÷ LIƯU KIĨU CON tr

Bài 1 :Bạn hãy lập chương trình cho phép ta nhập từ bàn phím một danh sách được ghép

nối Sau đó gỡ bỏ một record khỏi danh sách

Bài 2 :Bạn hãy lập chương trình cho phép nhập một danh sách được ghép nối Sau đó chèn thêm một record vào danh sách

Trang 27

Bài 3 :Bạn hãy lập chương trình cho phép nhập một danh sách được ghép nối Sau đó

đổi chỗ hai record trong danh sách

H

ướng dẫn :

CH¦¥NG TR×NH CON

1) Procedure Change ( n : integer ; Var St : String ) ;

(* thủ tục chuyển số tự nhiên n cho trước sang

hệ cơ số 2 và được lưu ở trong xâu St *)

Trang 28

Var Delta: real;

Trang 29

Write('Phuong trinh co nghiem kep : ');

Trang 30

Procedure Nhap(Var a, b, c: real);

Procedure input (Var a: real; tenbien: Char);

' lap thanh ba canh cua tam giac ')

Else Writeln('Khong lap thanh ba canh cua tam giac') ; End;

(*===============================*)

Procedure Trung_tuyen (a, b, c: Real);

Var ma, mb, mc: real;

Trang 32

4) Uses Crt;

Var a, b, c: real ;

(*================================*)

Procedure Nhap(Var a, b, c: real);

Procedure input (Var a: real; tenbien: Char);

' lap thanh ba canh cua tam giac ')

Else Writeln('Khong lap thanh ba canh cua tam giac') ; End;

Trang 33

(*===============================*)

Procedure Trung_tuyen (a, b, c: Real);

Var ma, mb, mc: real;

Trang 36

Function kt(ch: char; st: string): boolean;

(* Kiểm tra xem kí tự Ch có trong xâu St không Nếu có thì hàm trả về giá trị True Nếu không thì hàm trả về giá trị False *) Begin

For i:=1 to length(s1) do

If (not kt(s1[i],kq)) and (kt(s1[i],s2)) then

kq:=concat(kq,s1[i]);

End;

(*==============================*)

BEGIN

Trang 37

Clrscr;

Writeln('Nhap 2 xau S1 va S2 :');

Write('S1: '); Readln(xau1);

Write('S2: '); Readln(xau2);

Compare(xau1, xau2, xau);

If xau<>'' then Writeln('Xau chung la: ',xau)

Else Writeln('Khong co ki tu nao trong ca hai xau '); Write('Nhan ENTER de ket thuc ');

Var S: array[1 M] of string;

max, min, i, j, n: byte;

(*===============================*) Function D(U,V: string): byte;

(*Trả về tổng số loại kí tự không giống nhau

Trang 38

For id:=1 to length(U) do

If (pos(U[id],V)=0) and (pos(U[id],luu)=0) then luu:=concat(luu,U[id]);

For id:=1 to length(V) do

If(pos(V[id],U) = 0) and (pos(V[id],luu)=0) then luu:= concat(luu,V[id]);

d:=length(luu);

End;

(*=================================*) Procedure nhap;

Trang 39

(*===============================*) BEGIN (* Chương trình chính *)

If max<d(S[i],S[j]) then max:=d(S[i],S[j]);

If min>d(S[i],S[j]) then min:=d(S[i],S[j]); End;

Write('Max(d(Si,Sj)=',max,' Min(d(Si,Sj)=',min); Readln;

Trang 40

Procedure nhap(Var NN:longint);

Ngày đăng: 07/02/2015, 00:00

TỪ KHÓA LIÊN QUAN

TRÍCH ĐOẠN

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN

w