Yêu cầu: Cho hai xâu kí tự S1 và S2 (có không quá 255 ký tự). Hãy tìm một xâu con chung S dài nhất của hai xâu S1 và S2. Ví dụ: S1 = ’Ky thi học sinh gioi Tinh môn Tin hoc’, S2 = ’hoc sinh gioi mon Tin hoc’ thì S = ‘hoc sinh gioi '.
Dữ liệu vào từ file văn bản Bai2.inp:
- Dòng đầu tiên ghi xâu S1;
- Dòng thứ hai ghi xâu S2.
Kết quả ghi ra file văn bản Bai2.out: Chỉ một số duy nhất là độ dài của xâu con chung dài nhất S. (Nếu hai xâu S1, S2 không có kí tự nào chung thì ghi số 0).
Ví dụ:
Bai2.inp Bai2.inp
Ky thi hoc sinh gioi Tinh mon tin hoc hoc sinh gioi mon Tin hoc
14
const fi='bai2.inp';
fo='bai2.out';
var s1,s2:string;
max:integer;
f:text;
{===============}
procedure doc;
begin
assign(f,fi); reset(f);
readln(f,s1);
readln(f,s2);
close(f);
end;
{===============}
procedure xuly;
var kq:string; i,j:integer;
begin
assign(f,fo); rewrite(f);
max:=0;
for i:=1 to length(s1) do for j:=1 to length(s1) do begin
kq:=copy(s1,i,j-i+1);
if pos(kq,s2)<>0 then
if max<j-i+1 then max:=j-i+1;
end;
writeln(f,max);
close(f);
end;
{==============}
begin doc; xuly; end.
Bài 6. Chuẩn hóa văn bản (đề thi học sinh giỏi lớp 12 tỉnh Thanh Hóa năm học 2010- 2011)
Một văn bản được gọi là văn bản chuẩn hóa nếu:
- Hai từ liền nhau có duy nhất một dấu cách
- Dấu ngắt câu (dấu chấm, dấu chấm phẩy, dấu chấm hỏi, dấu chấm than) được đặt sát vào từ ngay trước nó, sau đó mới đến dấu cách trống
- Dấu mở ngoặc đặt sát vào phía bên trái của từ bắt đầu mở ngoặc
- Dấu đóng ngoặc đặt sát vào phía bên phải của từ cuối cùng được đóng ngoặc Hãy viết chương trình kiểm tra và đưa một đoạn văn bản về dạng chuẩn
Dữ liệu vào: Tệp bai3.inp
Kết quả: Ghi vào tệp bai3.out văn bản đã được chuẩn hóa Ví dụ:
Bai3.inp Bai3.out
Thấy rét u tôi bọc lại mền Cô nàng cất rượu ủ thêm men . ( trích hoa và rượu của - Nguyễn Bính)
Thấy rét u tôi bọc lại mền Cô nàng cất rượu ủ thêm men . (trích hoa và rượu của - Nguyễn Bính)
const fi='bai3.inp';
fo='bai3.out';
var f,g:text;
st:array[1..1000] of ansistring; n,i:longint;
{=================}
procedure doc;
var dem,i:longint;
begin
assign(f,fi);
reset(f);
dem:=0;
while not eof(f) do begin
inc(dem);
readln(f,st[dem]);
end;
n:=dem;
close(f);
end;
{================}
procedure chuanhoa(var x:ansistring);
var dau:string; vt:longint; s:ansistring;
begin s:=x;
while s[1]=' ' do delete(s,1,1);
while s[length(s)]=' ' do delete(s,length(s),1);
while pos(' ',s)<>0 do begin
vt:=pos(' ',s);
delete(s,vt,1);
end;
dau:=' .';
while pos(dau,s)<>0 do delete(s,pos(dau,s),1);
dau:='.';
while (pos(dau,s)>0) and (pos(dau,s)<length(s)) and (s[pos(dau,s)+1]<>' ')do insert(' ',s,pos(dau,s)+1);
dau:=' ;';
while pos(dau,s)<>0 do delete(s,pos(dau,s),1);
dau:=';';
while (pos(dau,s)>0) and (pos(dau,s)<length(s)) and (s[pos(dau,s)+1]<>' ')do insert(' ',s,pos(dau,s)+1);
dau:=' ?';
while pos(dau,s)<>0 do delete(s,pos(dau,s),1);
dau:='?';
while (pos(dau,s)>0) and (pos(dau,s)<length(s)) and (s[pos(dau,s)+1]<>' ')do insert(' ',s,pos(dau,s)+1);
dau:=' !';
while pos(dau,s)<>0 do delete(s,pos(dau,s),1);
dau:='!';
while (pos(dau,s)>0) and (pos(dau,s)<length(s)) and (s[pos(dau,s)+1]<>' ')do insert(' ',s,pos(dau,s)+1);
dau:=' )';
while pos(dau,s)<>0 do delete(s,pos(dau,s),1);
dau:='( ';
while pos(dau,s)<>0 do delete(s,pos(dau,s)+1,1);
x:=s;
x:=s;
end;
{================}
begin doc;
assign(g,fo); rewrite(g);
for i:=1 to n do begin
chuanhoa(st[i]);
writeln(g,st[i]);
end;
close(g);
readln;
end.
Bài 7. Tìm từ (Đề thi học sinh giỏi lớp 12 tỉnh Bạc Liêu năm 2011-2012)
Cho xâu khác rỗng. Tìm từ đầu tiên dài nhất trong xâu (Từ là một dãy liên tiếp không có dấu cách)
Dữ liệu vào: Từ tệp cau2.inp gồm một dòng duy nhất
Dữ liệu ra: Ghi vào tệp cau2.out gồm một dòng là từ tìm được
Cau2.inp Cau2.out
Hoc tin rat thu vi Hoc const fi='cau.inp';
fo='cau.out';
var s:ansistring;
max:integer;
f:text;
{===============}
procedure doc;
begin
assign(f,fi); reset(f);
readln(f,s);
close(f);
end;
{===============}
procedure xuly;
var kq,max,s1:ansistring; vt:longint;
begin
assign(f,fo); rewrite(f);
s1:=s; max:='';
while (pos(' ',s1)<> 0) and (length(s1)>0) do begin
vt:=pos(' ',s1);
kq:=copy(s1,1,vt-1);
delete(s1,1,vt);
if length(kq)>length(max) then max:=kq;
end;
writeln(f,max);
close(f);
end;
{==============}
begin doc; xuly; end.
Bài 8. Liệt kê chữ cái (đề thi học sinh giỏi lớp 12 năm học 2011-2012 tỉnh Bạc Liêu) Cho một văn bản chứa trong một tệp văn bản. Bạn hãy viết chương trình liệt kê các chữ cái chỉ có mặt trong văn bản đúng một lần theo thứ tự của bảng chữ cái (không phân biệt chữ hoa và chữ thường)
Dữ liệu vào: Tệp Dem_chu.inp gồm nhiều dòng chứa các ký tự trong tệp Dữ liệu ra: Tệp Dem_chu.out gồm nhiều dòng ghi các ký tự xuất hiện một lần.
Dem_chu.inp Dem_chu.out
NAM MOI HANH PHUC C
I O
P U const fi='dem_chu.inp';
fo='dem_chu.out';
var s:ansistring;
b:array['A'..'Z'] of longint;
f,g:text;
i:longint; ch:char;
{===============}
begin
assign(f,fi); reset(f);
assign(g,fo); rewrite(g);
fillchar(b,sizeof(b),0);
While not eof(f) do begin
readln(f,s);
for i:=1 to length(s) do
if s[i]<>' ' then inc(b[upcase(s[i])]);
end;
for ch:='A' to 'Z' do
if b[ch]=1 then writeln(g,ch);
close(f); close(g);
end.
Bài 9. Tìm số (đề thi học sinh giỏi lớp 12 bảng A năm học 2011-2012 tỉnh Bạc Liêu) Cho xâu s gồm ít nhất 3 kí tự số. Xóa bỏ một số kí tự trong xâu s chỉ để lại 3 kí tự số sao cho vân giữ nguyên thứ tự của chúng tạo nên số có giá trị lớn nhất.
Dữ liệu vào: Từ tệp cau2.inp gồm 1 dòng chứa xâu s
Dữ liệu ra: ghi vao tệp cau2.out xâu s chứa 3 kí tự số còn lại tạo thành số lớn nhất
cau2.inp cau.out
124512hoctin8126123 863 var f,g:text;
s:string;
{=====================}
procedure Nhap;
Begin
assign(f,'cau2.inp'); reset(f);
read(f,S);
close(f);
end;
{======================}
procedure xuly;
var i,j,k:byte;
begin i:=1;
repeat
if s[i] in ['0'..'9'] then inc(i) else delete(s,i,1);
until i>length(s);
for i:=1 to 3 do begin
k:=i;
for j:=i to length(s)+i-3 do if s[k]<s[j] then k:=j;
if k>i then delete(s,i,k-i);
end;
assign(f,'cau2.out'); rewrite(f);
writeln(f,copy(s,1,3));
close(f);
end;
{===========================}
Begin Nhap; xuly; readln; end.
Bài 10. Siêu đối xứng (http://vn.spoj.com/problems/NKSP)
Một xâu có độ dài lớn hơn 1 chỉ gồm các chữ cái la tinh in thường được gọi là đối xứng, nếu ta đọc xâu đó từ trái sang phải và từ phải sang trái là như nhau. Một xâu được gọi là siêu đối xứng, nếu nó là xâu đối xứng hoặc được tạo thành bằng cách ghép liên tiếp từ nhiều xâu đối xứng.
Yêu cầu: Cho một xâu S, hãy đếm số xâu con siêu đối xứng của S.( Xâu con của một xâu S là một đoạn liên tiếp các ký tự của S)
Dữ liệu Chứa xâu S với độ dài không vượt quá 1000.
Kết quả Ghi ra số xâu con tìm được.
Ví dụ Dữ liệu
abc Kết quả 0
Dữ liệu abacdc Kết quả 3
const fi='';
var s:ansistring;
f:text;
A:array[1..1000,1..1000] of boolean;
kq,i,j,k,n:longint;
{=============}
function kt(x,y:longint):boolean;
var u,h:longint;
begin
h:=(y-x) shr 1;
for u:=0 to h do
if S[x+u]<>S[y-u] then exit(false);
exit(true);
end;
{=============}
begin
assign(f,fi); reset(f);
read(f,s);
close(f);
kq:=0;
n:=length(s);
for i:=1 to n-1 do for j:=i+1 to n do
if kt(i,j) then A[i,j]:=true else A[i,j]:=false;
for i:=1 to n-3 do for j:=i+3 to n do for k:=i+1 to j-2 do
if (A[i,k])and(A[k+1,j]) then begin A[i,j]:=true;break;end;
for i:=1 to n-1 do for j:=i+1 to n do if A[i,j] then inc(kq);
write(kq);
end.
Bài 11. Writing (Nguồn http://vn.spoj.com/submit/PBCWRI)
Cho 2 chuỗi A,B chứa các chữ cái trong bảng chữ tiếng Anh (có cả chữ hoa và chữ thường). Chuỗi A có độ dài n, chuỗi B có độ dài m.
Yêu cầu: Đếm số lần xuất hiện của các hoán vị của chuỗi A trong chuỗi B.
Dữ liệu
Dòng đầu tiên chứa 2 số nguyên n và m.
Dòng thứ 2 chứa n kí tự của chuỗi A.
Dòng thứ 3 chứa m kí tự của chuỗi B.
Kết qủa
Một số duy nhất là kết quả của bài toán.
Giới hạn
n ≤ 3000
m ≤ 3 000 000
Ví dụ
Dữ liệu 4 11 cAda
AbrAcadAbRa Kết quả
2
Giải thích: 2 lần bắt đầu từ vị trí 4 và 5.
Const fi='PBCWRI.INP';
fo='PBCWRI.OUT';
Var B:array[1..3000001] Of Char;
D1,D2:array['a'..'z'] Of Longint;
C1,C2:array['A'..'Z'] Of Longint;
n,m,kq,i,x:Longint; h:char;
f,g:text;
Begin
assign(f,fi); reset(f);
assign(g,fo); rewrite(g);
Readln(f,n,m);
If m<n then Begin Write(0);
Exit;
End;
kq:=0;
Fillchar(D1,Sizeof(D1),0);
Fillchar(C1,Sizeof(C1),0);
D2:=D1;
C2:=C1;
For i:=1 to n do Begin
Read(f,h);
If (h>='a') And (h<='z') then Inc(D1[h]) Else Inc(C1[h]);
End;
Readln;
For i:=1 to n-1 do Begin
Read(f,B[i]);
If (B[i]>='a') And (B[i]<='z') then Inc(D2[B[i]]) Else Inc(C2[B[i]]);
End;
For i:=n to m do Begin
Read(f,B[i]);
If (B[i]>='a') And (B[i]<='z') then Inc(D2[B[i]]) Else Inc(C2[B[i]]);
x:=0;
For h:='a' to 'z' do
If D2[h]<>D1[h] then x:=1;
If x=0 then
For h:='A' to 'Z' do
If C1[h]<>C2[h] then x:=1;
If x=0 then Inc(kq);
x:=i-n+1;
If (B[x]>='a') And (B[x]<='z') then Dec(D2[B[x]]) Else Dec(C2[B[x]]);
End;
Write(g,kq);
close(f); close(g);
End.
Bài 12. Tìm mật khẩu (Đề thi chọn đội tuyển dự thi HSG Quốc gia năm 2012-2013) Việc bảo vệ máy tính của mình để hạn chế người khác thâm nhập vào là một vấn đề đặt ra cho mọi nguời sử dụng máy tính. Để tăng tính an toàn trong lưu trữ, một nguời đã quyết định dấu mật khẩu truy cập máy tính của mình vào một xâu T với một quy ước sao cho khi cần anh ta có thể lấy lại đuợc mật khẩu từ T như sau:
Là một người yêu thích số học anh ta thường chọn mật khẩu P là một số nguyên tố và đem dấu vào một xâu ký tự T sao cho P chính là số nguyên tố có giá trị lớn nhất trong số các số nguyên tố tạo được từ các xâu con của T (xâu con của một xâu ký tự T là một chuỗi liên tiếp các ký tự trong T).
Ví dụ: xâu T= “timpassword232432fsdgd45435dsfdsf” chứa mật khẩu là 43 vì T chứa các xâu con ứng với các số nguyên tố 2, 3, 23, 43, và 5.
Yêu cầu: Cho một xâu ký tự T chiều dài không quá 250 ký tự. Tìm mật khẩu P đã dấu trong xâu T biết P có giá trị nhỏ hơn 105. Dữ liệu cho đảm bảo T chứa ít nhất 1 số nguyên tố.
Dữ liệu: Vào từ file văn bản PASSWORD.INP gồm 1 dòng duy nhất là xâu T.
Kết quả: Ghi ra file văn bản PASSWORD.OUT chứa số P tìm được.
Ví dụ:
PASSWORD.INP PASSWORD.OUT
timpassword232432fsdgd45435dsfds f
43
const fi='password.inp'; fo='password.out';
var f:text; s:ansistring; max:int64;
{=================}
procedure doc;
begin
assign(f,fi); reset(f);
readln(f,s);
close(f);
end;
{=================}
function kiemtra(v:int64):boolean;
var i:longint;
begin
if v<=1 then exit(false);
for i:=2 to trunc(sqrt(v)) do if v mod i = 0 then exit(false);
exit(true);
end;
{=================}
procedure xuly;
var i,j:longint; v:int64;
begin
v:=0;max:=0;
for i:=1 to length(s) do begin
j:=i; v:=0;
while (j<=length(s)) do begin
if (s[j]<'1') or (s[j]>'9') then break;
v:=v*10+ ord(s[j]) - ord('0');
if kiemtra(v) and (v>max) then max:=v;
if v>100000 then break;
inc(j);
end;
end;
assign(f,fo); rewrite(f);
write(f,max);
close(f);
end;
{=================}
begin doc;
xuly;
end.
Bài 13. Biến đổi xâu ký tự (Đề thi chọn đội tuyển dự thi học sinh giỏi Quốc Gia lớp 12 năm học 2010-2011)
Cho n xâu ký tự A1A2...An(n£100). Mỗi xâu không quá 10 ký tự. Với một xâu s cho trước, hãy tìm tất cả các cách biểu diễn s dưới dạng ghép các xâu ký tự Ai, mỗi xâu ký tự Ai có thể xuất hiện trong một cách biểu diễn nào đó nhiều lần.
Dữ liệu vào: Tệp xau.inp có cấu trúc:
- Dòng đầu ghi xâu s - Dòng 2 ghi số n
- N dòng tiếp theo, dòng i ghi xâu Ai
Dữ liệu ra: Ghi vào tệp xau.out có cấu trúc:
- Nếu không có cách nào biểu diễn thì ghi không có
- Nếu có thì ghi mỗi cách trên một dòng theo ví dụ dưới đây xau.INP xau.OUT
abacd 6 ab cd a b c d
A[1]A[3]A[2]
A[1]A[3]A[5]A[6]
A[3]A[4]A[3]A[2]
A[3]A[4]A[3]A[5]A[6]
const fi='xau.inp';
fo='xau.out';
var f:text; s,s3,xau,tg:ansistring; n,max,dem,m1,m2:integer;
a,b:array[1..100] of string;
kq:array[1..100] of integer;
{=================}
procedure doc;
var i:integer;
begin
assign(f,fi);
reset(f);
readln(f,s);
readln(f,n);
for i:=1 to n do readln(f,a[i]);
close(f);
end;
{================}
function kiemtra(max:integer):boolean;
var s1:ansistring; t:integer;
begin
s1:='';
for t:=1 to max do begin
s1:=s1+a[kq[t]];
if s1=s then exit(true);
end;
exit(false);
end;
{================}
procedure result;
var t,j:integer; s1,xau1,xau:ansistring;
begin s1:='';
for t:=1 to max do begin
s1:=s1+a[kq[t]];
if s1=s then begin
for j:=1 to t do begin str(kq[j],xau1); xau:=xaứa['+xau1+']'; end;
inc(dem);
b[dem]:=xau;
exit;
end;
end;
end;
{================}
procedure try(i:integer);
var j:integer;
begin
if i<=length(s) then for j:=1 to n do begin
kq[i]:=j;
str(j,xau);
if kiemtra(i) then begin max:=i; result; end;
try(i+1);
end;
end;
{================}
procedure xuly;
begin
assign(f,fo); rewrite(f);
IF dem=0 then write(f,'khong co') else
begin
for m1:=1 to dem-1 do for m2:=m1+1 to dem do
if length(b[m1])>length(b[m2]) then begin
tg:=b[m1]; b[m1]:=b[m2]; b[m2]:=tg;
end;
for m1:=1 to dem-1 do for m2:=m1+1 to dem do if b[m1]>b[m2] then begin
tg:=b[m1]; b[m1]:=b[m2]; b[m2]:=tg;
end;
writeln(f,b[1]);
for m1:=2 to dem do
if b[m1]<>b[m1-1] then writeln(f,b[m1]);
end;
close(f);
end;
{=========}
begin doc;
try(1);
xuly;
end.