Tải bản đầy đủ (.doc) (4 trang)

Tài liệu Bài tập thực hành môn công nghệ phần mềm ppt

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (73.02 KB, 4 trang )

PHÂN LOẠI DẠNG BÀI TẬP
MÔN CÔNG NGHỆ PHẦN MỀM
(Tài liệu tham khảo)
I, DẠNG BÀI TẬP CHUYỂN CẤU TRÚC VỀ DẠNG TUẦN TỰ VÀ WHILE:
Bài 1:
Chuyển cấu trúc sau về dạng tuần tự và while:
if A then V else T;
Giải:
Chuyển cấu trúc "if A then V else T" về dạng tuần tự và while :
B := A ;
while A do
Begin
V;
A :=not A;
end;
while not B do
Begin
T;
B:= not B;
end;
Bài 2:
Chuyển cấu trúc sau về dạng tuần tự và while:
a) For i:= k to m do A
b) if X then Y
Giải:
a, Chuyển cấu trúc "for i:=k to m do A" về cấu trúc tuần tự và while
i:=k ;
while i<=m do
Begin
A;
i:=i+1;


end;
b, Chuyển về cấu trúc "if X then Y"
while X do
Begin
Y;
X:= not X
end;
Bài 3:
Chuyển cấu trúc sau vế dạng tuần tự và while:
a) if
A then V;
b) Repeat C until X;
Giải:
a, Chuyển cấu trúc "if A then V" về dạng tuần tự và while:
while A do
Begin
V ;
A := not A
end;
b, Chuyển cấu trúc "repeat C until X" :
C;
while not X do C
Bài 4:
Chuyển cấu trúc sau về dạng tuần tự và while:
a, For i:= m downto k do A ;
b, Repeat C until D ;
Giải:
a, Chuyển cấu trúc "for i:=m downto k do A" về dạng tuần tự và while
i:=m;
while i >=k do

Begin
A;
i:=i-1
end;
b, Chuyển cấu trúc "repeat C until D"
C;
while not D do C
II, DẠNG BÀI TẬP VỀ ĐẶC TẢ MA TRẬN:
Bài 1:
Cho ma trận vuông X cấp n, n lẻ. Đặc tả hình thức các điều kiện sau:
a) Tổng 2 phần tử ở 2 đầu đường chéo chính bằng 3 lần phần tử cuối cùng của hàng 1.
b) Phần tử giữa của hàng cuối bằng phần tử giữa của cột cuối.
Giải:
Đặc tả ma trận vuông cấp n lẻ : X = (xi j)n*n
xi j = x[ i, j ]
i, j =1..n
n = 2k + 1 , k thuộc N
a, Tổng 2 phần tử ở 2 đầu đường chéo chính bằng 3 lần phần tử cuối của hàng 1
x[ 1, 1 ] + x[ n, n ] = 3 * x[ 1, n ]
b, Phần tử giữa của hàng cuối bằng phần tử giữa của cột cuối
x[ n, (n+1)/2]=x[ (n+1)/2 , n]
Bài 2:
Cho ma trận vuông cấp n, n lẻ. Đặc tả hình thức các điều kiện sau:
a, Phần tử ở góc trên bên trái bằng phần tử ở góc dưới bên phải.
b, Phần tử ở tâm bằng trung bình cộng của 2 phần tử đầu đường chéo phụ
Giải:
Đặc tả ma trận vuông cấp n lẻ :
X = (xi j)n*n
xi j = x[ i, j ]
i, j =1..n

n = 2k + 1 trong đó k thuộc N
a, Phần tử góc trên bên trái bằng phần tử ở góc dưới bên phải
x[ 1, 1 ] = x[n, n]
b, Phần tử ở trung tâm bằng trung bình cộng của 2 phần tử đờng chéo phụ
x[ (n+1)/2, (n+1)/2 ] = (x[1, n] + x[n, 1])/2
III, DẠNG BÀI TẬP BẮT LỖI TRONG ĐOẠN CHƯƠNG TRÌNH:
Bài 1: Cho đoạn chương trình sau:
Uses crt;
Var u,v,t : real;
Function f: real;
Begin
u:= u/2;
f:= u+5*v-1;
End;
Begin
Write ('u=') ; readln(u);
Write ('v=') ; readln(v); t:=f;
Writeln (u:6:2 ,'/2 + 5*', v:6:2,'-1=',t:6:2);
Readln
End.
- Chương trình cho kết quả đúng hay sai? vì sao? Cho 1 ví dụ cụ thể.
Giải:
- Chương trình cho kết quả sai vì u là biến toàn cục, nó đợc sử dụng cả trong và ngoài CTC
và lệnh u:=u/2 trong hàm f đã làm thay đổi giá trị được nhập vào của u, lúc in ra kết quả sai
vì u bị giảm nửa giá trị.
- Ví dụ khi nhập u=4 v=3 thì kết quả in ra là 2/2 + 5*3 - 1 = 16
Bài 2: Cho đoạn chương trình sau:
Var u,v,t : real;
Funtion f : real;
Var x : real;

Begin
x:= u/2;
f:= x+5*v-1;
End;
Begin
Write ('u=') ; readln(u);
Write ('v=') ; readln(v); t:=f;
Writeln (u:6:2 ,'/2 + 5*', v:6:2,'-1=',t:6:2);
End.
- Chương trình cho kết quả đúng hay sai?
- Nếu thay x bằng u thì kết quả sẽ như thế nào?
Giải:
- Chương trình cho kết quả đúng.
- Nếu thay x bằng u thì kết quả sẽ sai vì khi gọi hàm f, u sẽ bị biến đổi giảm đi nửa giá trị.
Bài 3: Cho đoạn chương trình sau:
Uses crt;
Var u,v,t : real;
Function f: real;
Begin
u:= u/2;
f:= x+5*v-1;
End;
Begin
Write ('u=') ; readln(u);
Write ('v=') ; readln(v); t:=f;
Writeln (u:6:2 ,'/2 + 5*', v:6:2,'-1=',t:6:2);
Until (u=v);
Readln
End.
- Chương trình có dừng khi ta nhập v bằng u không ? giải thích?

Giải:
- Chương trình sẽ không dừng khi nhập u = v vì sau khi nhập 2 giá trị bằng nhau
nàychương trình tính t sẽ gọi đến hàm first và lúc đó u bị giảm đi do đó u khác v và vòng
lặp lại tiếp tục.
Bài 4: Cho đoạn chương trình sau:
Uses crt;
Var u,v,t : real;
Function f (u,v:real): real;
Begin
u:= u/2;
f:= x+5*v-1;
End;
Begin
Write ('u=') ; readln(u);
Write ('v=') ; readln(v); t:=f;
Writeln (u:6:2 ,'/2 + 5*', v:6:2,'-1=',t:6:2);
Readln
End.
- Chương trình cho kết quả đúng hay sai?
- Nếu thêm var trước u, v trong hàm f thì kết quả sẽ như thế nào?
Giải:
- Chương trình cho kết quả đúng vì u, v trong hàm là các biến địa phương được truyền theo
trị, tuy trùng tên với các biến toàn cục, viết như vậy sẽ khử được hiệu ứng phụ, nếu nhập
vào u=4, v=3 kết quả sẽ in ra : 4/2 + 5*3 - 1 = 16
- Nếu thêm var trước u, v trong hàm f thì kết quả sẽ sai vi sau khi gọi hàm, biến u bị thay
đổi giảm đi 1/2 kết quả sẽ là : 2/2 + 5*3 - 1 = 16






×