I Kiểu Logic (Boolean)

Một phần của tài liệu tin hoc co ban TH khong chuyen (Trang 33 - 99)

Trong cuộc sống chúng ta thờng hay gặp loại dữ liệu chỉ có hai giá trị: đúng (True) hoặc sai (False). Ví dụ khi ta viết 10>25 thì đây là một mệnh đề có giá trị False. Hoặc 1<4 là mệnh đề có giá trị True.

Một giá trị thuộc kiểu Boolean chỉ nhận một trong hai giá trị logic: TRUE (đúng) hoặc FALSE (sai). TRUE và FALSE là hai giá trị đợc định nghĩa sẵn.

Các phép toán sau cho kết quả cũng là kiểu Boolean: Phép AND (phép “và”)

Phép OR (phép “hoặc”) Phép NOT (phép “phủ định”) Phép XOR (phép “hoặc triệt tiêu”)

• Phép AND chỉ cho kết quả là TRUE khi và chỉ khi cả hai toán hạng đều TRUE.

• Phép OR chỉ cho kết quả là FALSE khi và chỉ khi cả hai toán hạng đều là FALSE.

• Phép XOR cho kết quả là TRUE khi giá trị hai toán hạng khác nhau. Còn nếu giá trị hai toán hạng giống nhau, sẽ cho kết quả là FALSE.

Ví dụ:

(3>5) AND (15>7) cho kết quả TRUE. (3<5) AND (15<7) cho kết quả là FALSE. (1>3) OR (4<7) cho kêt quả là TRUE. (1>3) OR (4<7) cho kết quả là FALSE. (1>3) XOR (4<7) cho kết quả là TRUE. (1>3) XOR (4>7) cho kết quả là FALSE. NOT (1>0) cho kết quả là TRUE.

NOT (1<9) cho kết quả là FALS. X. II. Kiểu số nguyên (Integer)

Một giá trị có kiểu nguyên là một phần tử của tập các số nguyên mà ta có thể xử lý đợc trên máy, tất nhiên nó chỉ là một tập nhỏ của các số nguyên chứ không phải tất cả mọi số nguyên đều có thể xử lý đợc trên máy tính. Kiểu số nguyễn đợc định nghĩa sẵn với từ khoá INTEGER.

Thông thờng nhất, các số nguyên đợc biểu diễn bằng hai byte (16 bit nên phạm vi của nó là từ –32768 (=-215) đến +32767 (=215-1).

Thí dụ:

+120, -267, -5, 13, 163...

Maxint là tên giá trị cực đại cho phép của kjiểu nguyên, nghĩa là Maxint = +32767.

Có kiểu Integer với độ dài byte. (xem phần sau).

10. II.1. Các phép tính số học đối với số nguyên:

• Phép cộng và phép trừ: +, - • Phép nhân: *

• Phép chia lấy kết quả là số thực:/ ví dụ 7/2 cho kết quả là 3.5. • Phép chia lấy kết quả là nguyên: Div

Ví dụ: 13 Div 2 cho kết quả 6.

• Phép chia lấy số d của hai số nguyên: MOD

Ví dụ: 7 MOD 4; cho ta giá trị bằng 3 là số d của phép tính.

• Hàm Boolean ODD(n) cho kết quả TRUE nếu n là một số lẻ, FALSE nếu n là số chẵn.

Chú ý: Khi thực hiện các phép tính số học đối với số nguyên, cần quan tâm xem các kết quả có vợt ra khỏi phạm vi biểu diễn số nguyên của máy hay không.

Ví dụ:

31950 +3800=35750 (vợt quá giới hạn).

11. II.2. Các phép tính quan hệ đối với số nguyên:

Các số nguyên có thể so sánh với nhau và cũng có thể so sánh với các số thực. Kết quả của phép toán so sánh là TRUE (đúng) hoặc FALSE (sai).

Ví dụ:

12<4 ch kết quả FALSE.

23<67.2345 cho kết quả TRUE. XI. III. Kiểu số thực (Real).

Tơng tự nh định nghĩa kiểu số nguyên, kiểu số thực là tập hợp các số thực có thể biểu diễn đợc trong máy tính và đợc máy định nghĩa sẵn với từ khoá Real.

Các phép toán cộng (+), trừ (-), nhân (*), chia (/) cũng nh các phép toán quan hệ (=,<>,<,>, >=,<=) đều có thể áp dụng cho các toán hạng là số thực lẫn toán hạng là số nguyên.

Tất nhiên không tồn tại các phép toán DIV, MOD cho kiểu số thực.

Các số thực đợc biểu diễn trong máy ở hai dạng: dạng dấu chấm tĩnh và dạng dấu chấm động (có phần số mũ ).

Dạng dấu chấm tĩnh nh sau: (Dấu chấm hay cho dấu phẩy thập phân).

gọi là tĩnh vì dấu chấm phần thập phân ở đầu đặc trng cho độ lớn của số đó.

Dạng dấu chấm động (có phấn mũ)

Gồm hai phần: Phần định dạng và phần mũ viết sau chữ E để biểu diễn số mũ của cơ số 10.

Ví dụ:

1233.45 =1.23345*103.

Biểu diễn bằng dấu chấm động nh sau:

1.23345E+03.

Gọi là động vì dấu chấm thập phân cha đủ để xác định độ lớn của số đó. Cách viết số thực nh sau là sai, là không đủ.

.8 (Phải viết là 0.8). 3. (Phải viết là 3.0 hoặc 3).

Các hàm số học chuẩn (dùng cho số nguyên và số thực):

Các hàm sau đây đợc định nghĩa sẵn và đợc sử dụng với đối số là các số thực hoặc các số nguyên:

• ABS(x) cho kết quả là trị tuyệt đối của x. • SQR(x) cho giá trị là x2.

• SIN(x), COS(x), ARCTAN(x) là các hàm lợng giác. • LN(x) hàm Log(x) =Ln(x).

• EXP(x) hàm ex.

• SQRT(x) hàm tính căn bậc hai của x.

• SUCC(n) đối số nguyên n, cho số nguyên tiếp theo n, tức là n+1. • PRED(n) đối số nguyên n, cho ta số nguyên trớc n, tức là n-1. • OĐD(n) đối số nguyên n, TRUE nếu n lẻ, FALSE nếu n chẵn.

• TRUND(x) kết quả là phần nguyên của x, tức là cắt bỏ đi phần lẻ thập phân của x. Ví dụ trunc(3.146) =3.

• ROUND(x) cho ta một số nguyên là phần nguyên của x bằng cách qui tròn phần lẻ thập phân của x. Ví dụ:

Round(6.76)=7. Round(6.36)=6. Round(-34.812)=-35.

XII. IV. Kiểu ký tự (character).

Máy tính không chỉ xử lý các dữ liệu bằng số mà còn có khả năng xử lý các dữ liệu văn bản (ký tự).

Hằng ký tự phải đặt trong mở nháy đơn và đống nháy đơn, ví dụ: ‘5’, ‘b’, ‘A’, ‘0’, ‘9’, ‘*’, ....

Máy tính dùng bộ ký tự để trao đổi thông tin qua các thiết bị vào – ra. Bộ ký tự đợc dùng phổ biến nhất là bộ ký tự ASCH (American Atandard Code for information interchange)- Hay còn gọi là bộ mã ASCH. Các ký tự dợc mã hoá bằng một byte, một byte có thể biểu diễn đợc 256 ký tự khác nhau. Các ký tự cơ bản nhất từ 0 đến 127 đợc gọi là ASCH chuẩn. Còn từ 128 đến 255 gọi là ASCH mở rộng và đợc dùng để mã hoá các ký tự riêng của một số ngôn ngữ, các ký tự toán học, đồ hoạ. Chúng ta quan tâm chủ yếu tới phần 128 ký tự đầu của bảng mã ASCh để xây dựng cú pháp cho lập trình.

Trong ASCH, các ký tự từ 0 đến 31 là các ký tự điều khiển, không in đợc, dùng để điều khiển các thiết bị ngoại vi, diều khiển việc trao đổi thông tin... Ví dụ khi máy nhận đợc ký tự số 7 (BEL), máy sẽ phát ra một tiếng kêu. Khi nhận đợc ký tự số 13 (CR; Carriage Return) con trỏ màn hình sẽ xuống đầu dòng tiếp theo. Khi nhận đợc 10 (LF: Line Feed) đầu kim in của máy in sẽ xuống đầu dòng tiếp theo....

Phần còn lại trong ASCH là mã của các chữ cái A,B,C... các chữ số 0,1,2,3,4...9, các ký tự đặc biệt... Ví dụ khi nhận đợc mã 65, máy sẽ hiện lên màn hình chữ cái A.

Riêng Mã 127 (Del) đợc dùng làm ký tự điều khiển xoá. Khi soạn chơng, phím Delete trên bàn phím chính là phím tạo ra mã só 127 để xoá một ký tự trên màn hình.

Hai hàm chuẩn ORD và CHR cho phép thiết lập tơng quan giữa mã ký tự và ký tự tơng ứng. Ví dụ:

• Hàm ORD(‘A’) cho kết quả 65, số thứ tự (mã) của ký tự ‘A’ trong bảng mã.

• Hàm CHR(65) cho ta ký tự A.

Đơng nhiên là CHR (ORD(‘A’) và ORD(CHR(65))=65. Ký tự VHR1 nhỏ hơn ký tự Chr2 nếu ORD(Chr1)<ỏd(Chr2). Hai cách viết sau là tơng đơng:

//65=CHR(65)

Hàm chuẩn PRED và SUCC có thể áp dụng cho đối số là kí tự, kết quả là ký tự. Giả sử Chr là một kí tự nào đó:

• Hàm PRED(Chr) cho kết quả là một ký tự cho kết quả là một ký tự nằm sau ký tự Chr, ví dụ SUCC(‘A’)=’B’nằm trớc ký tự Chr. Ví dụ PRED(‘B’)=’A’, Hàm SUCC(Chr)

XIII. V. Mô tả số nguyên với Word, Shortint, Longint.

Số nguyên ngoài Integer và byte còn có với các dạng Word, Shortint (Short integer), Longint (Long integer). Sau đây là bảng liệt kê các phạm vi của nó.

Byte 0..255 1

Shortint -128..127 1

Integer -32768...32767 2

Word 0..65535 2

Longint -214783648..21483647 4

Turbo Pascal còn cho phép biểu diễn số nguyên dới dạng hệ 16 (số Hexa) bằng cách dùng thêm dấu $ ở đầu. Ví dụ: $E có giá trị là 14 9hệ thập phân).

Một byte đợc biểu diễn bằng hai chữ số Hexa, vị một chữ số Hexa tơng đơng với số nhị phân 4 bít. Ta có bảng quan hệ sau:

Hệ 10 Hệ 2 Hệ 16 0 0000 0 1 0001 1 2 0010 2 3 0011 3 4 0100 4 5 0101 5 6 0101 6 7 0111 7 8 1000 8 9 1001 9 10 1010 A 11 1011 B 12 1100 C 13 1101 D 14 1110 E 15 1111 F Ví dụ: Hexa $7FFF=7*16^3+15*16^2+15*16^1=15*16^0=32767 (số hệ số 10). $8AB2=8*16^3+10*16^2+11*16^1+8*16^0=35506 (số hệ 10).

XIV. VI. Mở rộng khai báo kiểu số thực.Số thực còn có các dạng dau:Số thực còn có các dạng dau: Số thực còn có các dạng dau:

REAL 2.9E-39..1.7E+38 11-12 6

SINGLE 1.5E-45..3.4E+38 7-8 4

DOUBLE 5.0E-324..1.7E+380 15-16 8

Chơng 3: Khai báo, biểu thức và câu lệnh.

Biến, bảng, kiểu đều phải đợc khai báo trớc khi dùng trong chơng trình. XV. I. khai báo hằng.

Có các loại: Hằng, nguyên, hằng thực, hằng ký tự và hằng Boolean. Khai báo hằng: Các hằng đợc khai báo nh sau:

Const tên hằng = giá-trị của hằng;

Một dòng khai báo hằng đợc kết thúc bằng dấu chấm phẩy. Tên hằng đợc đặt theo qui tắc đã trình bày ở chơng trớc.

Ví dụ: Const X=5 (*Hằng nguyên*). Y=3.14 (*Hằng thực 5*). A=TRUE (*Hằng Boolean)l. Chr=’e’; (*Hằng ký tự e*).

Các hằng không thay đổi trong suốt chơng trình. XVI. II. Khai báo biến.

Biến (variable) là đại lợng có thể thay đổi giá trị trong quá trình xử lý. Tên biến của chơng trình đồng thời là địa chỉ của biến đó. Biến đợc khai báo nh sau:

Var

Tên_biến: Kiểu_dữ_liệu_của_biến;

Dấu hai chấm để ngăn cách hai phần của khai báo, dấu chấm phẩy kết thúc một dòng khi khai báo.

Nừu có nhiều biến cùng kiểu có thể đợc rút gọn bằng cách viết tên các biến đặt cách nhau dấu phẩy (,) ví dụ:

Var

a,b,c:real; i,j,k:Integer; T:Boolean;

XVII. III. Định nghĩa kiểu.

Đối với các dữ liệu cơ sở (Real, Integer, Byte, Char, Boolean) đã đợc định nghĩa sẵn nên ta khai báo biến trực tiếp ngay. Còn các kiểu dữ liệu khác ta phải định nghĩa kiểu.

Ví dụ: Type

Var

MauSac: Mau;

XVIII.IV. Biểu thức (Expression).

Một biểu thức gồm: toán tử (operator) và toán hạng (operand). Toán tử (dấu phép toán toán hạng có thể là hằng, hàm, biến.

Ví dụ: 14+ SQRT(5)- 2*COS(x).

Trong ví dụ này, các phép toán là phép cộng (+), phép trừ (-), và phép nhân (*). Các toán hạng là hằng số 14, hàm SQRT với đối số là 5, hằng 2 và hàm COS với đối số là biến x.

Biểu thức số học là biểu thức có giá trị hằng số (là Integer, byte, real). Biểu thức Boolean là biểu thức có giá trị là TRUE hoặc FALSE.

Một biểu thức chứa các toán tử quan hệ (<>,>,<,<=,>=,=) cũng đợc gọi là biểu thức Boolean hay một biểu thức quan hệ. Các toán hạng trong biểu thức quan hệ có thể là nguyên, thực, ký tự...

Thứ tự thực hiện từ trái qua phải với thứ tự u tiên nh sau:

Dấu ngoặc ( ) Biểu thức trong ngoặc đợc u tiên thứ

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, Xor 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

Các ví dụ sau minh hoạ về thứ tự tính toán. Ví dụ:

• 2+4*3 =2+(4*3) =2+12 =14.

• 3/2*4 =(3/2)*4 =1.5*4 =6.0. • 9 Div 2*4 =(9 div2)*4 =16.

• (2>3) and (‘c’ <’d’) =FALSE AND TRUE =FALSE.

• Nol(3+1 <5) OR (3>5 Div 30 =Nol (4<5)OR (3>1)= Nol True OR TRUE =FALSE OR TRUE =TRUE.

XIX. IV. Câu lệnh (Instruction, Statemment).

Ngoài phần mô tả dữ liệu còn có phần lệnh (instruction) của chơng trình. Phần này quy định các công việc mà chơng trình phải thực hiện để xử lý các dữ liệu. Các lệnh (hay cũng gọi là câu lệnh) cách nhau bởi dấu chấm phẩy. Câu lệnh đợc chia ra hai loại: Câu lệnh đơn giản và câu lệnh có cấu trúc.

• Câu lệnh đơn giản bao gồm: Lệnh gán (:=), lời gọi thủ tục, lệnh nhẩy GOTO.

• Câu lệnh có cấu trúc bao gồm:

Câu lệnh ghép (lệnh hợp thành): BEGIN...END:

Câu lệnh điều kiện và lựa chọn: if... then...else...case...of... Các vòng lặp: For...To...Do...

Repeat...Until... While...Do...

Với...làm: With...Do.

Mỗi một câu lệnh bao giờ cũng đợc đặt cách nhau bằng dấu chấm phẩy (;). Dấu chấm phẩy (;) chỉ có tác dụng ngăn cách các câu lệnh chứ không phải là dấu kết thúc câu lệnh và nó không thuộc vào câu lệnh. Pascal không bắt buộc phải viết mỗi câu lệnh một dòng. Vấn đề là phải trình bày chơng trình sao cho đẹp, rõ ràng, mô tả đợc thuật toán...

Ví dụ: Chúng ta có thể viết liền nhau trên một dòng chơng trình: A:=’Chao anh’; B:=TRUE;C:=12;

Hoặc viết thành từng dòng: A:=’Chao anh’;

B:=TRUE; C:=12;

Các lệnh có cấu trúc sẽ đợc đề cập ở các chơng sau. Còn thủ tục sẽ đợc đa vào cùng với các cấu trúc dữ liệu.

Phép gán

Phép gán dùng để gán giá trị của một biểu thức, một hằng vào một biến. Phép gán đợc viết nh sau:

Biến:=biểu_thức; Ví dụ:

A:=12; biến A nhận giá trị bằng 12 (hay đa 12 vào biến có địa chỉ A) B:=FALSE; biến B nhận giá trị là FALSE.

Ví dụ: Một biến X không thể nhận một giá trị Boolean đợc. X:=TRUE là sai.

Trờng hợp ngoại lệ: một biến nguyên không thể nhận một giá trị là số thực nhng một biến thực thì lại có thể nhận giá trị nguyên. Giả sử i là Integer. i:=9.5 là sai mà phải viết i:=Round(9.5). Nhng nếu X là biến thực, viết nh sau là đúng:

I:=12; X:=1;

Lệnh hợp thành hay lệnh ghép

Một nhóm câu lệnh đơn giản đợc đặt giữa hai chữ Begin và End sẽ tạo thành một câu lệnh ghép.

Chơng 4: Thủ tục vào, ra dữ liệu.

XX. I. Thủ tục hiển thị dữ liệu ra màn hình: Write và WritelnĐể hiển thị dữ liệu ra màn hình, Pascal có 3 cách viết nh sau:Để hiển thị dữ liệu ra màn hình, Pascal có 3 cách viết nh sau: Để hiển thị dữ liệu ra màn hình, Pascal có 3 cách viết nh sau:

Write(Item 1, Item2,...ItemN);

Writeln(Item1,Item2,...ItemN); (đọc là write line). Writeln;

Trong đó ( Item1,Item2,...ItemN0; là các mục cần hiển thị, có thể là một trong các loại sau:

Ví dụ:

• Hằng Writeln(3,12); Writeln(‘Chao ban!’);

• Biến Writeln(A);

• Hàm Writeln(Cos(x));

• Biểu thức Writeln(X+Y –2 +Exp(X));

• Một số kiểu có cấu trúc nh mảng, xâu ký tự (sẽ học sau).

Màn hình thông dụng hiện nay đợc phân thành 25 dòng, mỗi dòng có thể chứa 80 ký tự. ở mỗi thời điểm, tại một vị trí xác định trên màn hình có một khói sáng nhấp nháy gọi là con trỏ màn hình hay là dấu nhắc con trỏ.

Sự khác nhau của 3 cách viết trên là ở chỗ vị trí con trỏ màn hình sau khi kết thúc lệnh.

Cách viết Writeln(Item1, Item2,...ItemN); có ý nghĩa:

Sau khi hiển thị các giá trị của (Item1, Item2,...ItemN) trên cùng một dòng, con trỏ sẽ chuyển xuống dòng tiếp theo (con trỏ đợc đặt ở đầu dòng tiếp theo).

Cách viết Write(Item1,Item2,...ItemN);

Sau khi hiển thị các giá trị của (Item1, Item2,...ItemN) con trỏ sẽ không chuyển xuống đầu dòng tiếp theo 9con trỏ sẽ đợc đặt ở vị trí sau giá trị của ItemN).

Cách viết Write(Item1,Item2,...ItemN); là tơng đơng với khối lệnh nh sau: Begin Write(Item1); Write(Item2); ... Write(ItemN); End;

• Thủ tục Writeln; (không có tham số sẽ đặt con trỏ xuống đầu dòng tiếp theo. Vì vậy

Begin

Write(Item1,Item2,...,ItemN); Writeln;

End;

Trong khi dùng thủ tục Write và Writeln, có hai cách trình bày dữ liệu in ra là cách viết không qui cách và cách viết có qui cách. Chúng ta sẽ xét cụ thể lệnh viết ra với từng kiểu dữ liệu.

12. I.1. Viết ra kiểu số nguyên.

Cách viết không qui cách:

Var I:integer; Begin I:=345; Writeln(I); Writeln(-98671); End; Sẽ hiển thị ra màn hình: 345 -98671

cách viết khong qui cách không chỉ rõ qui cách hiển thị trong các thủ tục Write. Các số nguyên sẽ đợc viết ra với số chỗ bằng độ dài của nó (số chữ số của nó). ậ đây biến I có giá trị 345 chiếm 3 vị trí, còn –98671 chiếm 6 vị trí (5 chữ số và dấu - ) kể từ vị trí bên trái.

Cách viết có qui cách.

Ta có thể bố trí chỗ số cố định để hiển thị số nguyên bằng cách thêm dấu hai chấm(:) theo sau là số vị trí cần hiển thị. Máy sẽ xếp chỗ từ bên phải qua bên trái. Nếu thừa sẽ để trống ở bên trái.

Một phần của tài liệu tin hoc co ban TH khong chuyen (Trang 33 - 99)

Tải bản đầy đủ (DOC)

(99 trang)
w