Bài tập Pascal cơ bản đến nâng cao

1-Chỉ được dùng phép nhân, tính a mũ 28 với không hơn 6 phép nhân (khi Test, bạn nên cho a=2)

{Tinh a mu 28 chi dung khong hon 6 phep nhan}

Uses crt;

var a,b:longint;

Begin clrscr;

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

a:=a*a;

a:=a*a; Writeln('a mu 4=',a);

b:=a; {luu a mu 4 vao b}

a:=a*a*a; Writeln('a mu 12=',a);

a:=a*a; Writeln('a mu 24=',a);

a:=a*b; Writeln('a mu 28=',a);

Readln

End

pdf214 trang | Chia sẻ: tieuaka001 | Lượt xem: 656 | Lượt tải: 0download
Bạn đang xem trước 20 trang nội dung tài liệu Bài tập Pascal cơ bản đến nâng cao, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
h:=readkey; if ch=#27 then stop:=true; End; 8 h 54 m 28/7/2017 139 Thầy Trần Thông Quế Procedure Music; Begin sound(Mc[g][1]); delay(mc[g][2]*8);{ delay(20000);} nosound; if g=210 then g:=1 else inc(g) End; Procedure Try(i:integer); Var j:integer; Begin j:=0; repeat inc(j); if a[j] and b[i+j] and c[i-j] then begin h[i]:=j; Put_Queen((i-1)*50+10,(j-1)*50+10); Music; a[j]:=false;b[i+j]:=false;c[i-j]:=false; if i<8 then Try(i+1) else Wait; a[j]:=True;b[i+j]:=true;c[i-j]:=true; Put_Queen((i-1)*50+10,(j-1)*50+10); Music; end; until (j=8) or stop; End; Procedure Search; Var i:integer; s:string[30]; Begin t:=0;g:=1; stop:=false; for i:=1 to 8 do a[i]:=true; for i:=2 to 16 do b[i]:=true; for i:=-7 to 7 do c[i]:=true; Try(1); str(t,s); if stop then s:='Da Tim Duoc '+s+' Loi Giai' else s:='Tong So Co '+s+' Loi Giai'; setcolor(red); settextstyle(2,0,6); outtextxy(418,280,s); setcolor(white); settextstyle(2,0,7); 8 h 54 m 28/7/2017 140 Thầy Trần Thông Quế outtextxy(430,310,'Go Esc Ket Thuc !'); repeat ch:=readkey until ch=#27; End; BEGIN Initgr; Table; Search; Closegraph; END. = = = = = = = = = = = = = = = = = = = = = = PHẦN VIII. GRAPH THEORY & APPLICATIONS VIII.1-TÌM KIẾM TRÊN ĐỒ THỊ (tên khác: DUYỆT ĐỒ THỊ); TÔ MÀU ĐỒ THỊ; TÌM MIỀN LIÊN THÔNG CỦA ĐT. (Nếu quên OR lơ mơ về lý thuyết một vấn đề nào đó, các bạn nên đến thư viện – để mất ít tiền nhất- xem quyển: LÝ THUYÊT ĐỒ THỊ, nxb GIÁO DỤC 2012. Tác giả: Trần Thông Quế) A/ CÁC THUẬT TOÁN TÌM KIẾM (DUYỆT) TRÊN ĐỒ THỊ. 1-Hãy cài đặt trực quan (đồ họa hóa code) hai thuật toán DBF và BFS trên cùng một bản Code (BÀI CƠ BẢN NHƯNG KHÔNG DỄ!). Yêu cầu: * Gõ ENTER để chuyển từ thuật toán DFS sang BFS và ngược lại, * Gõ ESC để thoát CODE: PROGRAM DFS_BFS_SEARCH; USES CRT,GRAPH; CONST R=15;DL=500;N=8;VC=100; {KHONG CO DUONG DI THI DAT VO CUC VC=100} C:ARRAY[1..8] OF INTEGER=(150,330,450,450,330,150,30,30); D:ARRAY[1..8] OF INTEGER=(30,30,150,330,450,450,330,150); CL:ARRAY[0..3] OF WORD=(BLUE,YELLOW,WHITE,WHITE); NL:ARRAY[0..3] OF WORD=(YELLOW,BLUE,RED,BLACK); TYPE CSD=0..VC; AR=ARRAY[CSD] OF CSD; QUEUE=RECORD REAR:CSD; ELEMENT:AR; END; VAR G:ARRAY[CSD,CSD] OF BOOLEAN; 8 h 54 m 28/7/2017 141 Thầy Trần Thông Quế I,J,K,U:CSD; P:AR; (*-----------------------------------------------------------*) PROCEDURE INITGR; { KHOI TAO DO HOA} VAR GD,GM:INTEGER; BEGIN GD:=DETECT; INITGRAPH(GD,GM,'..\BGI'); IF (GRAPHRESULT GROK) THEN BEGIN WRITELN('LOI KHOI TAO DO HOA, GO ENTER KET THUC !'); READLN; HALT(1) END END; (*-----------------------------------------------------*) PROCEDURE ADD(X:CSD;VAR Q:QUEUE); {THEM PHAN TU TU DUOI HANG DOI} BEGIN WITH Q DO BEGIN REAR:=REAR+1; ELEMENT[REAR]:=X END; END; (*-----------------------------------------------------*) PROCEDURE DELETE(VAR Q:QUEUE;VAR X:CSD); {BOT PHAN TU KHOI HANG DOI} VAR K:CSD; BEGIN WITH Q DO BEGIN X:=ELEMENT[1]; FOR K:=1 TO REAR-1 DO ELEMENT[K]:=ELEMENT[K+1]; REAR:=REAR-1 END; END; (*-----------------------------------------------------*) PROCEDURE VENUT(U:CSD;M1,M2:WORD); {VE CAC DINH DO THI} VAR ST:STRING[3]; BEGIN SETFILLSTYLE(1,M2); SETCOLOR(M1); FILLELLIPSE(C[U],D[U],R,R); STR(U,ST); OUTTEXTXY(C[U]-2,D[U]-2,ST); END; (*-------------------------------*) 8 h 54 m 28/7/2017 142 Thầy Trần Thông Quế PROCEDURE LINK(X,Y:CSD;M:WORD); BEGIN SETCOLOR(M); LINE(C[X],D[X],C[Y],D[Y]); END; (*-------------------------------*) PROCEDURE DATA_AUTO_CREA; {TU DONG TAO DU LIEU NGAU NHIEN CHO PROG.} BEGIN RANDOMIZE; FOR I:=1 TO N DO BEGIN G[I,I]:=FALSE; FOR J:=I+1 TO N DO BEGIN G[I,J]:=RANDOM(3)=1; G[J,I]:=G[I,J] END; END; FOR I:=1 TO N DO BEGIN J:=0; REPEAT J:=J+1 UNTIL G[I,J] OR (J=N); IF (J=N) AND (NOT G[I,N]) THEN BEGIN J:=1+RANDOM(N); IF J=I THEN IF I<N THEN J:=I+1 ELSE J:=I-1; G[I,J]:=TRUE;G[J,I]:=TRUE END; END; END; (*--------------------------------------------------*) PROCEDURE DEMO(ST:STRING); {IN TEN CAC VIEC} BEGIN SETCOLOR(WHITE); OUTTEXTXY(500,30,'Duyet Do Thi'); OUTTEXTXY(500,90,ST); SETCOLOR(YELLOW); OUTTEXTXY(490,150,'Go Enter Tiep Tuc ...'); SETCOLOR(RED); OUTTEXTXY(490,210,'Go Esc Ket Thuc !'); END; (*--------------------------------------------------*) PROCEDURE PRINT_GRAPH; {IN DO THI} VAR ST:STRING[3]; 8 h 54 m 28/7/2017 143 Thầy Trần Thông Quế BEGIN SETBKCOLOR(BLUE);CLEARDEVICE; SETFILLSTYLE(1,DARKGRAY); BAR(0,0,GETMAXY,GETMAXY); FOR I:=1 TO N DO FOR J:=1 TO N DO IF G[I,J] THEN LINK(I,J,NL[0]); LINE(C[I],D[I],C[J],D[J]); FOR I:=1 TO N DO VENUT(I,CL[0],NL[0]); END; (*--------------------------------------------------*) PROCEDURE VE_GR_BFS(U:CSD); {HIEN THI DO THI DE DUYET THEO BE RONG} VAR Q:QUEUE; BEGIN VENUT(U,CL[K],NL[K]); P[U]:=0; Q.REAR:=0; ADD(U,Q); WHILE Q.REAR0 DO BEGIN DELETE(Q,I); FOR J:=1 TO N DO IF G[I,J] THEN IF P[J]=VC THEN BEGIN P[J]:=I; LINK(I,J,NL[K]); VENUT(J,CL[K],NL[K]); VENUT(I,CL[K],NL[K]); ADD(J,Q); DELAY(DL); END; END; END; (*--------------------------*) PROCEDURE BFS; {DUYET THEO CHIEU RONG} BEGIN FOR U:=1 TO N DO P[U]:=VC; K:=0; FOR U:=1 TO N DO IF P[U]=VC THEN BEGIN K:=(K+1) MOD 4; VE_GR_BFS(U);DELAY(DL) END; END; (*--------------------*) PROCEDURE VE_DT_DFS(U:CSD); {HIEN THI DO THI DE DUYET THEO CHIEU SAU} 8 h 54 m 28/7/2017 144 Thầy Trần Thông Quế VAR T:CSD; BEGIN I:=I+1; P[U]:=I; FOR T:=1 TO N DO IF G[U,T] THEN IF P[T]=0 THEN BEGIN LINK(U,T,NL[K]); VENUT(U,CL[K],NL[K]); VENUT(T,CL[K],NL[K]); DELAY(DL); VE_DT_DFS(T); END; END; (*-----------------------------*) PROCEDURE DFS; {DUYET THEO CHIEU SAU} BEGIN FOR I:=1 TO N DO P[I]:=0; I:=0; FOR U:=1 TO N DO IF P[U]=0 THEN BEGIN K:=(K+1) MOD 4; VENUT(U,CL[K],NL[K]); VE_DT_DFS(U);DELAY(DL) END; END; (*-----------------------------------*) PROCEDURE PROC_CALL_PROC; {THU TUC GOI CAC THU TUC DUYET} VAR KT:CHAR; BEGIN IF KEYPRESSED THEN REPEAT KT:=READKEY UNTIL NOT KEYPRESSED; REPEAT DATA_AUTO_CREA; PRINT_GRAPH; DEMO('Theo Be Rong'); KT:=READKEY; IF KT=#27 THEN EXIT; BFS; KT:=READKEY; IF KT=#27 THEN EXIT; PRINT_GRAPH; DEMO('Theo Do Sau'); KT:=READKEY; IF KT=#27 THEN EXIT; 8 h 54 m 28/7/2017 145 Thầy Trần Thông Quế DFS; KT:=READKEY; UNTIL (KT=#27); END; (*-----------------------------------*) BEGIN (* CHUONG TRINH CHINH *) CLRSCR; INITGR; PROC_CALL_PROC; CLOSEGRAPH; END. Thử một bài duy nhất ở mức TRÊN CƠ BẢN về duyệt theo BFS: 2-(IOI-1996: THI OLYMPIC TIN HỌC QUỐC TẾ 1996) Tiếp theo thành tựu khối lập phương kỳ diệu, ông Rubik phát minh dạng cải biên phẳng của khối này và ông gọi đó là các ô vuông kỳ diệu. Đó là một bảng 8 ô vuông có kích thước như nhau được tô màu khác nhau. Các màu tô được ký hiệu bởi 8 số nguyên dương đàu tiên (xem hình ngay trên) viết lần lượt theo chiều kim đồng hồ, bắt đầu từ ô góc trên cùng trái và kết thúc ở ô góc dưới cùng trái. Một cấu hình như trên gọi là cấu hình ban đầu. Ta thực hiện 3 phép biến đổi cơ bản ký hiệu là ‘A’, ‘B’, ‘C’ để tác động lên cấu hình của bảng, trong đó: • ‘A’: Đổi chỗ dòng trên và dòng dưới • ‘B’: Thực hiện phép hoán vị theo chiều sang phải vòng quanh bảng. • ‘C’: Quay theo chiều kim đồng hồ 4 ô ở giữa Mọi cấu hình đều có thể được tác động bởi 3 phép biến đổi cơ bản nói trên. Và tác động của 3 phép biến đổi cơ bản ấy mô tả bởi hình dưới đây: (Ở MỖI BỘ DATA DƯỚI ĐÂY CÁC SỐ TRÊN CÙNG VÀ DƯỚI CÙNG LÀ VỊ TRÍ CÁC Ô CỦA BẢNG) BẢNG 1 1 2 3 4  INDEX của các ô 8 7 6 5  INDEX của các ô BẢNG 2 1 2 3 4 8 7 6 5 1 2 3 4 8 7 6 5 4 1 2 3 5 8 7 6 8 h 54 m 28/7/2017 146 Thầy Trần Thông Quế BẢNG 3 Các số ghi ở ngoài bảng chỉ vị trí các ô của bảng. Nếu một ô ở vị trí p chứa số i thì có nghĩa là sau khi làm phép biến đổi tương ứng, ô vuông mà vị trí trước lúc biến đổi của nó là i sẽ được chuyển đến vị trí p. a) Hãy viết program tìm dãy các phép biến đổi để đưa cấu hình ban đầu về một cấu hình đích cho trước. b) Bạn sẽ được thêm 2 điểm nếu số phép biến đổi của bạn không quá 300 * Dữ liệu vào cất trên text file Data.in gồm: - Một dòng duy nhất chứa 8 số nguyên mô tả cấu hình đích. * Kết quả ghi lên text file Data.ou: -Dòng đầu tiên ghi số các phép biến đổi L - Tại L dòng tiếp theo ghi ký hiệu các phép biến đổi đã nói trên theo TRÌNH TỰ mà program của bạn đã thực hiện MỘT VÍ DỤ CỤ THỂ CỦA BÀI TOÁN NÀY CHO DƯỚI ĐÂY Data.In 2 6 8 4 5 7 3 1 Data.Ou 7 B C A B C C B Program MagicSquare; {BAI NAY DUYET DO THI THEO BFS) Uses crt; Const kt=8; m=40320; fi='Data.In'; fo='Data.Ou'; Type Bd=array[1..kt] of 1..kt; Ht=array[1..kt] of 1..kt; Const thuan:Array['A'..'C'] Of Bd=((8,7,6,5,4,3,2,1),(4,1,2,3,6,7,8,5), (1,7,2,4,5,3,6,8)); {Cac b_doi co ban} nguoc:Array['A'..'C'] of Bd=((8,7,6,5,4,3,2,1),(2,3,4,1,8,5,6,7), (1,3,6,4,5,7,2,8)); {Nguoc cua b_doi} dau:Ht=(1,2,3,4,5,6,7,8); {Trang thai ban dau} Var dic:Ht; {Bien luu trang thai dich} s:String; {Day cac b_doi dua tr_thai dau den tr_thai dich} fact:Array[0..kt] of Longint; {mang luu tu 0! den 8!} last:Array[0..m] of Char; {last[sh(dic)] la ky tu cuoi cung cua day cac} {b_doi dua trang thai dau ve trang thai dich} {Neu last[sh(dic)]=' ' thi dich cung rong (tuc dich khong duoc sinh} Procedure Nhap; Var tepvao:text; i:word; Begin 1 7 2 4 8 6 3 5 8 h 54 m 28/7/2017 147 Thầy Trần Thông Quế Assign(tepvao,fi); Reset(tepvao); For i:=1 to kt Do Read(tepvao,dic[i]); Close(tepvao); End; {Het nhap lieu} Procedure Facto; {Tinh giai thua} Var i:word; Begin fact[1]:=1; fact[0]:=1; For i:=2 to kt Do fact[i]:=i*fact[i-1]; End; Function sh(p:Ht):Word; {ham sh de tinh so hieu cua mot hoan vi bat ky} Var res, L, i,j:Word; Begin res:=0; For i:=1 to kt Do Begin L:=0; {L- so cac phan tu cua p o cac vi tri tu 1->i-1 nhỏ hơn p[i]} For j:=1 to i-1 Do If p[j]<p[i] Then Inc(L);{cố định i-1 p_tủ đầu tiên của p thì có (p[i]-1-L)} {so nho hon p[i] tai cac vi tri i trong cac hoan vi} {So cac hoan vi q ma i-1 p_tu ®au tien giong nhu cua p} {nhung dung truoc p theo thu tu tu dien bang (p[i]-1-L)*fact(kt-i)} res:=res+(p[i]-1-L)*fact[kt-i]; End; {Het for cua i} sh:=res; End; {Ket thuc ham sh} Procedure App(dic:Ht; x:char; Var r:Ht); {Duoc r bang cach ap dung b_doi x len trang thai dich} Var i:word; Begin For i:=1 to kt Do r[i]:=dic[thuan[x][i]]; End; Procedure bd_nguoc(dic:Ht; x:Char; Var r:Ht); {Duoc r bang cach bien doi nguoc cua b_doi x len trang thai dic} Var i:Word; Begin For i:=1 to kt Do r[i]:=dic[nguoc[x][i]]; end; {Het bd_nguoc} Function bang(r, dic:ht):Boolean; {ham bang nhan g_tri True neu r=dic} Var i:Word; Begin bang:=true; For i:=1 to kt Do If r[i]dic[i] then Begin 8 h 54 m 28/7/2017 148 Thầy Trần Thông Quế bang:=false; exit; End; End; Procedure sinh; {Tao day cac b_doi tu tr_thai dau de dat tr_thai dich} {last[sh(dic)] la phep b_doi cuoi cung cua day} Const qs=700; {kich thuoc danh sach} Var hdoi:Array[0..qs-1] of ht; {Khai bao hang doi chua cac b_doi} notfound:Boolean; head, tail, i, rankq:Word; r, s:Ht; x:Char; Begin For i:=0 to m Do last[i]:=' '; {khoi tri} last[0]:='.'; head:=0; tail:=1; hdoi[0]:=dau; notfound:=true; While notfound Do Begin r:=hdoi[head]; Inc(head); If head=qs Then head:=0; For x:='A' to 'C' Do Begin App(r, x, s); rankq:=sh(s); If last[rankq]=' ' Then Begin last[rankq]:=x; If bang(dic,s) Then Begin notfound:=false; break; End; hdoi[tail]:=s; Inc(tail); If tail=qs Then tail:=0; End; End; End; End; {ket thuc thu tuc sinh} Procedure tim; {kien tao cac phep bien doi} Var rankq:Word; x:Char; p,q:Ht; Begin q:=dic; rankq:=sh(q); s:=' '; While rankq0 do Begin 8 h 54 m 28/7/2017 149 Thầy Trần Thông Quế x:=last[rankq]; s:=x+s; bd_nguoc(q,x,p); q:=p; rankq:=sh(q); End; End; Procedure Xuat; Var tepra:text; L,i:word; Begin Assign(tepra,fo); rewrite(tepra); L:=length(s); Writeln(tepra, L-1); For i:=1 to L do Writeln(tepra, s[i]); Close(tepra); End; Begin {Main Prog.} clrscr; Nhap; Facto; Sinh; Tim; Xuat; Writeln('Done!'); readln; End. B/ CÁC THUẬT TOÁN TÌM CÁC MIỀN LIÊN THÔNG TRÊN ĐỒ THỊ B.1) TÌM MIỀN LIÊN THÔNG TRÊN ĐỒ THỊ VÔ HƯỚNG 3- Cài đặt thuật toán tìm & liệt kê các thành phần (miền) liên thông của một đồ thị vô hướng. Biết rằng cấu trúc của đồ thị vô hướng được biểu diễn bởi danh sách liệt kê cạnh như sau (Ds này lưu trên Text File LTHG.IN): 13 10 1 2 1 3 2 3 4 5 4 7 5 6 8 9 10 12 11 12 12 13 Kết quả lưu trên file Xuat.kq CODE: Để đạt được mục tiêu đề bài ta duyệt đồ thị Đệ quy theo DFS 8 h 54 m 28/7/2017 150 Thầy Trần Thông Quế Program Dem_so_thp_lthong; uses crt; const max=50; fi='lthg.in'; fo='xuat.kq'; {Du lieu vao la Ds liet ke canh!} type m1=Array[0..max] of integer; m2=Array[1..max,1..max] of byte; var a:m2; {ma tran danh sach liet ke canh} n:integer; v:m1; sm:integer; {so mien lien thong} Procedure Nhap; var f:text; i,j:integer; Begin Assign(f,fi); Reset(f); Read(f,n); FillChar(a,sizeof(a),0); {khoi tri cho mang a} While not seekeof(f) do {tao ma tran luu dinh dau va cuoi cua moi canh} Begin Read(f,i); While not seekeoln(f) do Begin Read(f,j); a[i,j]:=1; a[j,i]:=1; End; Readln(f); End; Close(f); End; Procedure DFS(i:integer); Var j:integer; Begin For j:=1 to n do If v[j]=0 then {neu j chua thuoc mien lien thong nao thi} If a[i,j]=1 then {neu j ke voi i thi } Begin v[j]:=sm; {ghi nho dinh j cung mien lth sm voi i} DFS(j); {duyet tiep do thi theo chieu sau tu dinh j} End; End; Procedure Xuly; Var s:integer; Begin FillChar(v,sizeof(v),0); sm:=0; For s:=1 to n do 8 h 54 m 28/7/2017 151 Thầy Trần Thông Quế If v[s]=0 then Begin Inc(sm); {danh so cho mien lth moi} v[s]:=sm; {s la dinh dau tien phat hien thuoc mien lth moi} DFS(s); {Duyet dthi tim tat ca cac dinh lth voi s} End; End; Procedure ghikq; var f:text; i,j:integer; Begin Assign(f,fo); Rewrite(f); Writeln(f,'So mien lien thong la:',sm); For i:=1 to sm do Begin For j:=1 to n do If v[j]=i then Write(f,j,' '); Writeln(f,'<-- Day la cac dinh o mien Lt thu ',i); End; close(f); End; Procedure Inkq; var f:text; line:string[50]; Begin Assign(f,fo); Reset(f); While not seekeof(f) Do Begin Readln(f,line); Writeln(line); End; Close(f); End; Begin clrscr; Nhap; Xuly; Ghikq; Inkq; Writeln; Write('Go ENTER de thoat!'); Readln; End. 8 h 54 m 28/7/2017 152 Thầy Trần Thông Quế B.2) TÌM MIỀN LIÊN THÔNG MẠNH TRÊN ĐỒ THỊ CÓ HƯỚNG (THỰC CHẤT LÀ CÀI ĐẶT THUẬT TOÁN TARJAN) 4/ Cài đặt thuật toán tìm & liệt kê các miền liên thông MẠNH của đồ thị có hướng (thuật toán TARJAN). Biết rằng đồ thị có hướng này được biểu diễn bởi ds cung sau đây (và ds này lưu trên text file LTH_MANH.IN): 11 15 1 2 1 8 2 3 3 4 4 2 4 5 5 6 6 7 7 5 8 9 9 4 9 10 10 8 10 11 11 9 Kết quả lưu trên file LTH_MAMH.OU CODE: (Về duyệt đồ thị, bài này cũng dùng DFS) Program Tarjan_Alg; Uses crt; Const fi='LTH_MANH.IN'; fo='LTH_MANH.OU'; Type lk=^nut; nut=record s:word; next:lk; End; cay=array[0..200] of lk; m1=array[0..200] of word; Var sv,id,m,n,top:word; {m:so dinh; n:so canh} Num,Low,p,s:m1; dsk:cay; f:Text; Procedure Nhap; Var i,u,v: word; t:lk; Begin Assign(f,fi); Reset(f); Readln(f,m,n); {doc so dinh m, so canh n tu tep vao cac bien nho m,n} For i:=1 to n Do Begin Readln(f,u,v); New(t); 8 h 54 m 28/7/2017 153 Thầy Trần Thông Quế t^.s:=v; t^.next:=dsk[u]; dsk[u]:=t; End; Close(f); End; Function min(u,v:word):word; Begin If u<v Then min:=u Else min:=v; End; Procedure DFS(i:word); Var j:word; t:lk; Begin Inc(id); Num[i]:=id; Low[i]:=Num[i]; t:=dsk[i]; Inc(top); s[top]:=i; While Not (t=Nil) Do Begin j:=t^.s; If p[j]=0 then If Num[j]=0 then Begin DFS(j); Low[i]:=min(Low[i], Low[j]); End Else Low[i]:=min(Low[i], Num[j]); t:=t^.next; End; If Low[i]=Num[i] then Begin Inc(sv); Repeat j:=s[top]; {lay 1 phan tu ra khoi Stack tai dinh, luu vao j} dec(top); {Khi do so phan tu o Stack giam di mot} p[j]:=sv; Until i=j; End; End; Procedure Visit; var i:word; Begin For i:=1 to m do 8 h 54 m 28/7/2017 154 Thầy Trần Thông Quế If Num[i]=0 then DFS(i); End; Procedure Xuat; Var i,j:word; Begin Assign(f,fo); Rewrite(f); Writeln;Writeln; Writeln(f,'So mien lien thong la:',sv); For i:=1 to sv Do Begin For j:=1 to m Do If p[j]=i then write(f,j,' '); Writeln(f,'-> Cac dinh thuoc mien lien thong thu ',i,'.'); End; Close(f); end; Procedure Inkq; Var f:Text;line:String; Begin Assign(f,fo); Reset(f); While Not SeekEof(f) Do Begin Readln(f,line); Writeln(line); End; Close(f); End; { Main Program } Begin clrscr; Nhap; Visit; Xuat; Inkq; Readln; End. B.3) BÀI TOÁN TÔ MÀU ĐỒ THỊ 5- Hãy dùng số màu ít nhất để tô màu đồ thị có N đỉnh, sao cho hai đỉnh BẤT KỲ KỀ NHAU phải được tô bằng màu KHÁC NHAU. Yêu cầu: 1-Đồ họa hóa Code 2-Cấu trúc đồ thị tự động thay đổi nhờ nhấn phím ENTER; nhấn ESC để thoát. CODE: PROGRAM COLOR_GRAPH; 8 h 54 m 28/7/2017 155 Thầy Trần Thông Quế USES CRT,GRAPH; CONST R=15;DL=500;VC=100;N=8; C:ARRAY[1..8] OF INTEGER=(150,330,450,450,330,150,30,30); D:ARRAY[1..8] OF INTEGER=(30,30,150,330,450,450,330,150); CL:ARRAY[0..4] OF WORD=(WHITE,RED,YELLOW,BLUE,GREEN); TYPE CSD=0..VC; VAR G:ARRAY[CSD,CSD] OF BOOLEAN; V,V0,V1:SET OF CSD; I,J,K:CSD; (*------------------------------------------------------------*) PROCEDURE INITGR; VAR GD,GM:INTEGER; BEGIN GD:=DETECT; INITGRAPH(GD,GM,'..\BGI'); IF (GRAPHRESULT GROK) THEN BEGIN WRITELN('LOI KHOI TAO DO HOA, GO ENTER KET THUC !'); READLN; HALT(1) END END; (*-----------------------------------------------------*) PROCEDURE VENUT(U:CSD;M:WORD); BEGIN SETFILLSTYLE(1,M);SETCOLOR(M); FILLELLIPSE(C[U],D[U],R,R); END; (*-------------------------------*) PROCEDURE LINK(X,Y:CSD;M:WORD); BEGIN SETCOLOR(M); LINE(C[X],D[X],C[Y],D[Y]); END; (*-------------------------------*) PROCEDURE INIT_GRAPH; BEGIN RANDOMIZE; FOR I:=1 TO N DO BEGIN G[I,I]:=FALSE; FOR J:=I+1 TO N DO BEGIN G[I,J]:=RANDOM(3)=1; G[J,I]:=G[I,J] END; 8 h 54 m 28/7/2017 156 Thầy Trần Thông Quế END; FOR I:=1 TO N DO BEGIN J:=0; REPEAT J:=J+1 UNTIL G[I,J] OR (J=N); IF (J=N) AND (NOT G[I,N]) THEN BEGIN J:=RANDOM(N)+1; IF J=I THEN IF I<N THEN J:=I+1 ELSE J:=I-1; G[I,J]:=TRUE;G[J,I]:=TRUE END; END; END; (*--------------------------------------------------*) PROCEDURE MENU_PRINT; BEGIN SETCOLOR(WHITE); OUTTEXTXY(500,30,'Son Do Thi'); SETCOLOR(YELLOW); OUTTEXTXY(490,90,'Go Enter Tiep Tuc ...'); SETCOLOR(RED); OUTTEXTXY(490,150,'Go Esc Ket Thuc !'); END; (*--------------------------------------------------*) PROCEDURE PRINT_GRAPH; BEGIN SETBKCOLOR(BLUE);CLEARDEVICE; SETFILLSTYLE(1,DARKGRAY); BAR(0,0,GETMAXY,GETMAXY); FOR I:=1 TO N DO FOR J:=1 TO N DO IF G[I,J] THEN LINK(I,J,CL[0]); LINE(C[I],D[I],C[J],D[J]); FOR I:=1 TO N DO VENUT(I,CL[0]); END; (*--------------------------------------------------*) PROCEDURE COLORING; {To mau do thi} VAR CHECK:BOOLEAN; BEGIN V0:=V;K:=0; WHILE V0[] DO BEGIN K:=K+1; I:=0; REPEAT I:=I+1 UNTIL I IN V0; VENUT(I,CL[K]); DELAY(DL); 8 h 54 m 28/7/2017 157 Thầy Trần Thông Quế V1:=[I]; FOR I:=1 TO N DO IF I IN V0 THEN BEGIN J:=0; REPEAT J:=J+1; CHECK:=G[I,J] AND (J IN V1); UNTIL CHECK OR (J=N); IF NOT CHECK THEN BEGIN VENUT(I,CL[K]); DELAY(DL); V1:=V1+[I]; END; END; V0:=V0-V1; END; END; (*---------------------------------------*) PROCEDURE PROC_CALL_PROC; {THU TUC GOI CAC THU TUC} VAR KT:CHAR; BEGIN IF KEYPRESSED THEN REPEAT KT:=READKEY UNTIL NOT KEYPRESSED; REPEAT INIT_GRAPH; PRINT_GRAPH; MENU_PRINT; COLORING; KT:=READKEY; UNTIL (KT=#27); END; (*--------------------------------------*) BEGIN (* CHUONG TRINH CHINH *) CLRSCR; INITGR; V:=[]; FOR I:=1 TO N DO V:=V+[I]; PROC_CALL_PROC; CLOSEGRAPH; END. 8 h 54 m 28/7/2017 158 Thầy Trần Thông Quế VIII-2/ ĐỒ THỊ EULER & ĐỒ THỊ HAMILTON A) ĐỒ THỊ EULER 6- Liệt kê các đường đi Euler trên đồ thị vô hướng được biểu diễn bởi ma trận kề dưới đây: 9  Số đỉnh của đồ thị (Bắt buộc phải có dữ liệu này!) 0 1 1 0 0 0 0 0 0 1 0 1 0 0 0 0 0 0 1 1 0 1 0 1 0 0 0 0 0 1 0 1 0 0 0 0 0 0 0 1 0 1 0 1 1 0 0 1 0 1 0 1 1 0 0 0 0 0 0 1 0 1 0 0 0 0 0 1 1 1 0 1 0 0 0 0 1 0 0 1 0 CODE: Program Duongdi_Euler; uses crt; Label L1; Const max=30; Type mg1=array[1..max,1..max] of byte; mg2=array[1..max] of boolean; mg3=array[1..max] of integer; Var c:mg1; check:mg2; i,j,u,n,dem1,dem:integer; f:text; tf:string[12]; Function l_thg(u,v:integer; ktra:mg2):integer; var i,j,d,k,l:integer; p:mg3; Begin c[u,v]:=0; c[v,u]:=0; For i:=1 to n do p[i]:=0; d:=0; For i:=1 to n do Begin If (p[i]=0) and ktra[i] then Begin Inc(d); p[i]:=d; for j:=1 to n do for L:=1 to n do If (p[j]=0) and ktra[j] and (p[L]=d) and (c[L,j]=1) then p[j]:=d; End; End; c[u,v]:=1; c[v,u]:=1; L_thg:=d; End; 8 h 54 m 28/7/2017 159 Thầy Trần Thông Quế {Main Prog.} Begin clrscr; Write('Nhap ten tep du lieu:'); readln(tf); Assign(f,tf); Reset(f); Readln(f,n); For i:=1 to n do For j:=1 to n do Read(f,c[i,j]); Close(f); Write('Cho biet dinh xuat phat:'); Readln(u); Writeln('Duong di Euler tim duoc:'); Writeln; dem:=0; For j:=1 to n do check[j]:=true; L1:dem1:=0; For j:=1 to n do If c[u,j]=1 then Inc(dem1); dem:=dem+1; If dem1=1 then Begin For j:=1 to n do If c[u,j]=1 then Begin check[u]:=false; c[u,j]:=0; c[j,u]:=0; Writeln('Di qua canh thu ',dem,' dung 1 lan la tu:',u,'->',j); u:=j; Goto L1; End; End Else Begin For j:=1 to n do If c[u,j]=1 then Begin If L_thg(u,j,check)=1 then Begin c[u,j]:=0; c[j,u]:=0; Writeln('Di qua canh thu ',dem,' dung 1 lan la tu:',u,'->',j); u:=j; Goto L1; End End End; Readln; End. 7- Tìm và hiển thị chu trình EULER trên đồ thị biểu diễn bởi danh sách liệt kê cạnh. Yêu cầu: Program phải chạy được cả với đồ thị vô hướng và đồ thị có hướng (đồ thị vô hướng: gõ 0; đồ thị có hướng: gõ 1). Test1: Dùng file vào DTEUL.IN 8 h 54 m 28/7/2017 160 Thầy Trần Thông Quế 4 5 -> 4 đỉnh; 5 cạnh (Bắt buộc phải có hai data này!) 1 2 1 4 2 3 2 4 3 4 Test 2: Dùng file vào EU1.IN 5 6 1 2 1 5 2 5 3 4 3 5 4 5 B) ĐỒ THỊ HAMILTON 8- Tìm và hiển thị đường đi Hamilton trên đồ thị vô hướng được biểu diễn bởi danh sách liệt kê cạnh. Test1: Dùng file vào DTEUL.IN 4 5 1 2 1 4 2 3 2 4 3 4 Test 2: Dùng file vào EU1.IN 5 6 1 2 1 5 2 5 3 4 3 5 4 5 9/ (Bài này bạn thử test với ma trận kề của đồ thị) Tìm và liệt kê chu trình Hamilton trên đồ thị được biểu diễn bởi ma trận kề dưới đây. 8 0 1 1 1 0 0 0 0 1 0 0 0 1 0 0 0 1 0 0 1 1 0 0 0 1 0 1 0 0 1 1 0 0 1 1 0 0 1 0 1 0 0 0 1 1 0 1 0 0 0 0 1 0 1 0 1 0 0 0 0 1 0 1 0 8 h 54 m 28/7/2017 161 Thầy Trần Thông Quế CODE: Program Chutrinh_Hamilton; Uses crt; Var i,j,n:Integer; c:Array[1..20,1..20] of byte; p:Array[1..20] of byte; b:array[1..20] of boolean; d:Word; f1,f2:Text; Procedure Xuly; Label l1; Var t:integer; ktra:boolean; Begin ktra:=true; For t:=1 to n-1 Do If c[p[t],p[t+1]]=0 then Begin ktra:=False; goto L1; End; If c[p[n],p[1]]=0 then ktra:=False; L1:If ktra then Begin d:=d+1; Write(f2,'Chu trinh Hamilton thu ',d,' la:'); For t:=1 to n Do Write(f2,p[t]:3); Writeln(f2); End; End; Procedure test(k:integer); Var i1,j:integer; Begin For j:=1 to n do If b[j] then Begin p[k]:=j; b[j]:=False; If k=n then xuly Else test(k+1); b[j]:=True; End; End; {Main Prog.} Begin clrscr; Assign(f1,'CtHamil.Inp'); Reset(f1); Assign(f2,'CtHamil.Out'); Rewrite(f2); Readln(f1,n); For i:=1 to n do For j:=1 to n do Read(f1,c[i,j]); 8 h 54 m 28/7/2017 162 Thầy Trần Thông Quế Close(f1); For i:=1 to n do b[i]:=True; d:=0; Test(1); Close(f2); Writeln('DONE!'); Writeln('Go Enter de quay ve chuong trinh!'); Writeln('De xem ket qua, go phi

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

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