Ngôn ngữ lập trình Pascal - Phần 1

Tính tương thích của các kiểu dữ liệu Về nguyên tắc, 2 vế phải cùng kiểu dữ liệu. Biến nguyên I không thể gán := ‘A’;  Ngoại lệ: biến thực nhận giá trị nguyên. X:= 6; Ngược lại một biến nguyên không thể nhận một giá trị thực. Muốn nhận phải dùng các hàm Round hoặc Trunc. I := Round( SQRT(X));

pdf36 trang | Chia sẻ: dntpro1256 | Lượt xem: 619 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Ngôn ngữ lập trình Pascal - Phần 1, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
1Biên soạn: Giảng bài: Ngôn ngữ lập trình 2Vì sao học PASCAL ?  PASCAL là ngôn ngữ lập trình cao cấp do GS Niklaus Wirth sáng tác đầu 70.  PASCAL giúp sinh viên viết chương trình có cấu trúc sáng sủa, rõ ràng, dễ hiểu và dễ đọc.  PASCAL là ngôn ngữ có cấu trúc mạnh mẽ cả về dữ liệu lẫn chương trình và lệnh. 3Algorithms+Data Structures=Programs Thuật giải+Cấu trúc dữ liệu=Chương trình 4Chương 1 Các phần tử cơ bản của PASCAL Bộ chữ viết của PASCAL  Các chữ cái ‘a’..’z’, ‘A’..’Z’  Không phân biệt chữ thường và hoa.  Các chữ số ‘0’..’9’  Dấu gạch nối _ rất tiện dụng  Các kí hiệu +, -, *, /, . , ; % ...  Dấu cách được dùng để ngăn cách các từ. 5Từ khoá là các từ của riêng PASCAL  Thí dụ: Program, Var, For, To, IF.... Tên hay Định danh (Indentifier) là dãy kí tự bắt đầu bằng một chữ cái, dùng để chỉ tên hằng số, tên một biến, tên kiểu, tên chương trình con...  Thí dụ: ta phải dùng tên Delta thay cho dấu  là kí hiệu không nằm trong bộ chữ viết PASCAL 6 Các tên đặt sai 1ABC, #DELTA, ARRAY, DEL TA  Dùng dấu gạch nối khi đặt tên GIAI_PHUONG_TRINH_BAC_HAI thay vì tên đúng song khó hình dung GIAIPHUONGTRINHBACHAI tên sai GIAI-PHUONG-TRINH-BAC-HAI  Tên bằng tiếng Việt ? 7 Dấu chấm phẩy ; dùng để ngăn cách câu lệnh (xem sau)  Lời giải thích (comment) cho rõ ràng hơn (* Lời giải thích có thể dùng tiếng Việt*) { Lời giải thích }  Sai nếu mở - đóng khác kiểu (* Sai }  Có thể viết nhiều dòng giải thích cho đến khi khoá lại (* Dòng 1 dòng 2 *) 8Lưu đồ cú pháp Được dùng để định nghĩa các cấu trúc trong PASCAL. Chính xác song rất rất ít dùng đến. Thí dụ: định nghĩa tên 9Cấu trúc chung của một chương trình PASCAL  Phần tiêu đề của chương trình  Phần khai báo dữ liệu - hằng, biến (Const, Var), - mô tả kiểu dữ liệu mới (Type) - khai báo chương trình con (Procedure, Function)  Phần thân chương trình chứa các lệnh để máy tính thực hiện 10 Thí dụ 1.1 PROGRAM THI_DU1; (* Dòng tiêu đề *) VAR R, A, Dien_Tich: Real; (* Khai báo ba biến thực *) BEGIN Write(' Bán kính R = '); READLN(R); (* Đọc giá trị của R *) Dien_Tich := PI*R*R; (* Tính diện tích hình tròn *) (* Viết ra màn hình kết quả tính *) Writeln(' Diện tích hình tròn = ', Dien_Tich); Write(' Cạnh hình vuông A = '); READLN(A); Dien_Tich := A*A; Writeln(' Diện tích hình vuông =', Dien_Tich); Readln; END. 11 Kết quả chạy chương trình Bán kính R = 2.56  Diện tích hình tròn = 2.0588741615E+01 Cạnh hình vuông A = 2.56  Diện tích hình vuông = 6.5536000000E+00 _ 12 PROGRAM TEN_CHUONG_TRINH; (* Dòng tiêu đề *) USES CRT, PRINTER;(*Lời gọi Sử dụng các đơn vị chương trình *) (* Phần khai báo dữ liệu và chương trình con *) LABEL... CONST ... TYPE ... VAR ... { Có thể có nhiều Procedure và nhiều Function } PROCEDURE ... FUNCTION ... (* Thân chương trình chính *) BEGIN (* Các lệnh được viết ở đây *) ...... END. 13 Các bước cơ bản khi viết chương trình Bước 1: Soạn thảo chương trình. Bước 2: Dịch và kết nối chương trình.  Biên dịch (compiler)  Thông dịch (Interpreter) (ít dùng) Bước 3: Chạy thử và sửa lỗi chương trình Turbo PASCAL của hãng Borland có môi trường khép kín, đảm bảo hoạt động của cả 3 bước trên trong một chương trình. 14 Bước 1: Thảo chương trình  Dùng chương trình soạn thảo văn bản (Text Editor) để viết chương trình với nhiều thao tác tiện dụng như xen, sửa, xoá, copy ...  Máy tính cổ phải viết chương trình bằng cách đục lỗ giấy.  Kết quả nhận được: các chương trình nguồn (source code) PASCAL: *.PAS 15 Bước 2: Dịch và kết nối chương trình  Biên dịch (compiler)  Khái niệm về Thông dịch (Interpreter)  Kết quả của bước dịch là các tệp *.OBJ và *.TPU  Tiếp theo phải liên kết các tệp *.OBJ và *.TPU lại để thành chương trình chạy được, đó là tệp *.EXE.  Nếu có lỗi về mặt cú pháp (syntax error), máy sẽ báo rõ lỗi loại nào, vị trí lỗi ... Thí dụ Begin viết thành Began 16 Bước 3: Chạy thử và sửa lỗi chương trình  Lỗi về thuật giải X2 viết nhầm thành X*2 Máy không thể phát hiện được  Lỗi về cách trình bầy, chưa đẹp ...  Nếu có lỗi, quay về bước 1 để sửa. 17 Lưu đồ lập trình Begin Dùng chương trình soạn thảo văn bản (EDITOR) để viết và sửa lỗi chương trình Gọi chương trình dịch COMPILER và chương trình kết nối LINKER Có lỗi cú pháp Chạy thử chương trình vừa được dịch xong Có lỗi thuật giải? Có muốn sửa lại cho đẹp? End Có Có Không 18  Dữ liệu là nguồn vật liệu cho máy tính xử lí. Máy tính chỉ hiểu các dữ liệu được biểu diễn dưới dạng mã nhị phân.  Trong ngôn ngữ bậc cao, dữ liệu được khái quát hoá thành các kiểu dữ liệu khác nhau. Chương Các kiểu dữ liệu. Các kiểu dữ liệu cơ sở. 19 kiểu logic Bun (Boolean) Kiểu cơ sở kiểu số nguyên (Integer) kiểu số thực (Real) Kiểu vô hướng kiểu kí tự (Char) (kiểu đơn giản) (Scalar Type hay kiểu khoảng con Kiểu Simple Type ) kiểu vô hướng (sub-range) dữ tự định nghĩa liệu kiểu liệt kê (enumerated) DATA TYPE Kiểu mảng (ARRAY) Kiểu dữ liệu có cấu trúc Kiểu tập (SET) (Structured Type) Kiểu bản ghi (RECORD) Kiểu tệp (FILE) Kiểu xâu kí tự (STRING) Kiểu con trỏ. (POINTER Type) 20 Định nghĩa một kiểu dữ liệu Một kiểu dữ liệu được xác định bởi 2 yếu tố: Một tập hợp các giá trị mà một biến thuộc kiểu đó có thể nhận được  Định nghĩa các phép toán trên tập giá trị đó. 21 Kiểu logic Boolean  Có hai giá trị FALSE và TRUE  Các phép toán AND, OR, XOR, NOT X Y X AND Y X OR Y X XOR Y FALSE FALSE FALSE FALSE FALSE FALSE TRUE FALSE TRUE TRUE TRUE FALSE FALSE TRUE TRUE TRUE TRUE TRUE TRUE FALSE 22 Các phép toán quan hệ  Kết quả luôn luôn là giá trị kiểu Boolean Kí hiệu phép toán ý nghĩa so sánh khác nhau = so sánh bằng nhau >= so sánh lớn hơn hoặc bằng <= so sánh nhỏ hơn hoặc bằng > so sánh lớn hơn < so sánh nhỏ hơn Thí dụ: 3 < 5 cho giá trị TRUE 23 Kiểu số nguyên Integer  Kiểu số nguyên khai báo với từ khoá Integer  Dùng 2 bytes (số nguyên 16 bít) để biểu diễn nên miền giá trị: -32768 đến +32767 Thí dụ: -327, -32000, 1, 123  Các phép tính: + - * / DIV MOD quan hệ (>, ...), logic (AND, OR...)  Phép chia số nguyên 3 / 2 = 1.5  Phép chia lấy phần nguyên 11 DIV 3 = ?  Phép chia lấy số dư nguyên 11 MOD 3 = ?  Cẩn thận tràn số: 32000+800-2000=29200 24 Một số phép toán cho số nguyên  Phép toán logic AND, OR, XOR, NOT Thí dụ: 3 AND 5 = 1 vì 0000 0000 0000 0011 3 AND 0000 0000 0000 0101 5 -------------------------------------------- Kết quả: 0000 0000 0000 0001 1  Phép dịch trái SHL (Shift Left), dịch phải SHR (Shift Right) để tính nhanh hơn 3*24= 3 SHL 4, 3 / 24 = 3 SHR 4 25 Kiểu số nguyên Byte  Kiểu số nguyên khai báo với từ khoá Byte  Dùng 1 byte để biểu diễn số nguyên dương nên miền giá trị: 0 đến 255 .  Tiết kiệm ô nhớ.  Các phép tính: giống như Integer. 26  Kiểu số thực khai báo với từ khoá Real  Dùng 6 bytes để biểu diễn, dải giá trị: -1.7E-38 đến +1.7E+38  Dải giá trị lớn và độ chính xác cao.  Các phép tính +, -, *, /, quan hệ  Không tồn tại DIV, MOD, logic  Có 2 cách viết: - Bình thường: - 3.14, -24.123445 - Dạng viết có phần mũ: -2.4123445E-1  Cách viết sai: 5. .5 Kiểu số thực Real 27 Các hàm số học chuẩn Các hàm số học sau đã được định sẵn và dùng cho số nguyên và số thực  ABS(x)  SQR(x) cho x2, SQRT(x) căn bậc hai của x  SIN(x), COS(x), arctan(x) với x: radian  Ln(x), Exp(x)  Succ(n), Pred(n): n nguyên  Odd(n) là TRUE nếu n lẻ.  Round(x) và Trunc(x) làm tròn hoặc cắt Sẽ học áp dụng sau. 28  Kiểu kí tự khai báo với từ khoá Char  Gồm - chữ cái ‘a’..’z’, ‘A’..’Z’ - chữ số ‘0’..’9’ - kí hiệu khác: . , ; : ! @ # $ % ^ & * ( )  Bảng mã ASCII (Americain Standard Code for Information Interchange). ý nghĩa.  Các hàm ord(‘c’) và chr(n)  Thứ tự c1 < c2 nếu ord(‘c1’) < ord(‘c2’)  Hàm Succ và Pred Kiểu kí tự Char 29 Kiểu đếm được và không đếm được Kiểu đếm được: Integer, Byte, Boolean, Char, đoạn con, liệt kê Kiểu vô hướng Kiểu không đếm được: Real 30 Khai báo hằng với mẫu Const Tên_hằng = Giá_trị_của_hằng;  Thí dụ: Const Dung=TRUE; (* Hằng Boolean *) A=5; { Hằng số nguyên } PI = 3.14; { Hằng số thực } Ch=‘Z’; (* Hằng kí tự *) Chương 3 Khai báo hằng, biến, kiểu. Biểu thức. Câu lệnh. 31 Khai báo biến Tên biến là tên của ô nhớ cất dữ liệu. Giá trị của nó có thể thay đổi được. Var Tên_biến : Kiểu_dữ_liệu_của_biến;  Thí dụ: Var M23, A25, AAA: Real; MY_NAME: String[25]; Y: Boolean; X: Integer; 32 Biểu thức bao gồm toán tử và toán hạng. Biểu thức số học cho ta giá trị số. Biểu thức logic cho ta giá trị logic Bun. Trình tự ưu tiên tính toán biểu thức DÊu ngoÆc ( ) BiÓu thøc trong ngoÆc ®­îc ­u tiªn nhÊt NOT, - (dÊu trõ) C¸c phÐp to¸n mét to¸n h¹ng *, /, DIV, MOD, AND C¸c phÐp tÝnh lo¹i nh©n, cïng møc ­u tiªn +, -, OR, X OR C¸c phÐp tÝnh lo¹i céng, cïng møc ­u tiªn =, , =, >, <, IN C¸c phÐp to¸n quan hÖ, cã cïng møc ­u tiªn 33 Thí dụ 3.3 7 + 3*5 = 7 + (3*5) = 22 5/2*3 = (5/2) * 3 = 7.5 18 DIV 4*4 = (18 DIV 4)*4 = 16 2*(3 + 5) = 16 Thí dụ 3.4: biểu thức Boolean (100 > 76) AND ('B' < 'A') TRUE AND FALSE FALSE 34 Phép gán Biến := biểu thức;  Vế trái chỉ có thể và chỉ là một tên biến. X:=6; X:=X+3; X= ? X := 4*X+X*X; X= ? M23 := 18/X*4.0+SQRT(X); M23 = ? X+2 := 3; ? 35 Tính tương thích của các kiểu dữ liệu Về nguyên tắc, 2 vế phải cùng kiểu dữ liệu. Biến nguyên I không thể gán := ‘A’;  Ngoại lệ: biến thực nhận giá trị nguyên. X:= 6; Ngược lại một biến nguyên không thể nhận một giá trị thực. Muốn nhận phải dùng các hàm Round hoặc Trunc. I := Round( SQRT(X)); 36 Lệnh hợp thành Begin Begin BEGIN Begin Câu lệnh 1; End; Câu lệnh 2; Begin ........ End; Câu lệnh N; End; END; Begin End; End; Và cấu trúc khối lệnh

Các file đính kèm theo tài liệu này:

  • pdfngon_ngu_lap_trinh_pascalchuong1_2_3_4903_1810340.pdf
Tài liệu liên quan