Nguồn đề bài cặp ghép không trọng số: http://vn.spoj.com/problems/MATCH1/
1. Đề bài cặp ghép không trọng số
Cho đồ thị hai phía G = (X U Y, E); Các đỉnh của X ký hiệu là x1, x2, …, xm, các đỉnh của Y ký hiệu là y1, y2, …, yn.
Một bộ ghép trên G là một tập các cạnh thuộc E đôi một không có đỉnh chung.
Yêu cầu: Hãy tìm bộ ghép cực đại (có nhiều cạnh nhất) trên G.
Chú ý : Dùng Eof chứ không dùng SeekEof.
Input
• Dòng 1: Chứa hai số m, n (1 ≤ m, n ≤ 100)
• Các dòng tiếp, mỗi dòng chứa hai số nguyên dương i, j cho biết thông tin về một cạnh (xi, yj) thuộc E.
Output
• Dòng 1: Ghi số cạnh trong bộ ghép cực đại tìm được (K).
• K dòng tiếp theo, mỗi dòng ghi thông tin về một cạnh được chọn vào bộ ghép cực đại: Gồm 2 số u, v thể hiện cho cạnh nối (xu, yv).
Example

Input:
4 5
1 1
1 4
2 1
2 2
2 4
3 2
3 3
4 2
4 3
Output:
4
1 1
2 4
3 3
4 2
2. Code cặp ghép không trọng số Pascal
Đây là code thuật toán cặp ghép thôi. không có hướng dẫn gì cả.
Code mẫu cặp ghép được viết dựa trên Cuốn DSAP của thầy Lê Minh Hoàng, giáo viên khối chuyên Sư Phạm.
const fi='';
nmax=1000;
type data=longint;
var
f:text;
A:array[0..nmax+1,0..nmax+1] of byte;
Q,MatchX,MatchY,tr:array[0..nmax+1] of data;
n,m,dau,cuoi:data;
procedure docfile;
var i,j,u,v:data;
begin
assign(f,fi); reset(f);
fillchar(a,sizeof(a),0);
readln(f,m,n);
while not eof(f) do
begin
readln(f,u,v);
a[u,v]:=1;
end;
close(f);
end;
procedure them(x:data);
begin
inc(cuoi);
q[cuoi]:=x;
end;
function lay:data;
begin
lay:=q[dau];
inc(dau);
end;
function BFS:data;
var i,j,u,v:data;
begin
dau:=1;
cuoi:=0;
fillchar(tr,sizeof(tr),0);
for i:=1 to m do
if matchX[i]=0 then
them(i);
while dau<=cuoi do
begin
u:=lay;
for v:=1 to n do
if (a[u,v]=1) and (tr[v]=0) then
begin
tr[v]:=u;
if matchy[v]=0 then
exit(v);
them(matchy[v]);
end;
end;
exit(0);
end;
procedure enlager(u:data);
var
v,next:data;
begin
repeat
v:=tr[u];
next:=matchx[v];
matchx[v]:=u;
matchy[u]:=v;
u:=next;
until u=0;
end;
procedure xuli;
var i,j,res,d:data;
begin
fillchar(matchx,sizeof(matchx),0);
fillchar(matchy,sizeof(matchy),0);
repeat
d:=bfs;
if d<>0 then
enlager(d);
until d=0;
res:=0;
for i:=1 to m do
if matchx[i] <>0 then
inc(res);
writeln(res);
for i:=1 to m do
if matchx[i]<>0 then
writeln(i,' ',matchx[i]);
end;
begin
docfile;
xuli;
end.