Đề thi Toán - Tin trong nhà trường Bài 91

doc4 trang | Chia sẻ: huu1989 | Lượt xem: 1323 | Lượt tải: 0download
Bạn đang xem nội dung tài liệu Đề thi Toán - Tin trong nhà trường Bài 91, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
Bài 91/2002 - Các số lặp
(Dành cho học sinh THCS và THPT)
Program bai91;
{Thuat toan lua bo vao chuong}
{$A+,B-,D+,E+,F-,G-,I+,L+,N-,O-,P-,Q-,R+,S+,T-,V+,X+}
{$M 16384,0,655360}
USES crt;
CONST M1 = MaxInt div 4 + 1;
 M2 = MaxInt;
 fi = 'Bai91.Inp';
TYPE MA = Array[0..M1] of LongInt;
Var A: Array[0..3] of ^MA;
 d,l :LongInt;
Procedure Init;
 Var i:Byte;
Begin
 For i:=0 to 3 do
 begin
 New(A[i]);
 Fillchar(A[i]^,sizeof(A[i]^),0);
 end;
 End;
Procedure ReadF(k:ShortInt);
Var f:Text;
 x:LongInt;
 i,j:Integer;
Begin
 Init;
 Assign(f,fi);
 Reset(f);
 While Not SeekEof(f) do
 begin
 Read(f,x);
 x:=x*k;
 If x>=0 then
 begin
 i:=x div M1;
 j:=x mod M1;
 If i=4 then begin i:=3; j:=M1; end;
 Inc(A[i]^[j]);
 If A[i]^[j]>d then begin d:=A[i]^[j]; l:=x*k; end;
 end;
 end;
 Close(f);
 For i:=0 to 3 do Dispose(A[i]);
End;
BEGIN
 Clrscr;
 d:=0; l:=0;
 ReadF(-1);
 ReadF(1);
 Writeln('So lap nhieu nhat la: ',l,#10#13,'Voi so lan lap : ',d);
 Readln;
END.
(Lời giải của Nguyễn Toàn Thắng *)
Bài giải của bạn Nguyễn Toàn Thắng dùng thuật toán lùa bò vào chuồng. Sau đây là cách giải khác dùng thuật toán đếm số lần lặp.
Thuật toán: Tư tưởng thuật toán là dùng mảng đánh đấu có nghĩa là số x thì Lap[x] sẽ là số lần xuất hiện của số x trong mảng. Vì số phần tử của mảng nhỏ hơn hoặc bằng 106 nên phần tử của mảng Lap phải là kiểu dữ liệu để có thể lưu trữ được 106. Số x là số nguyên kiểu integer và do giới hạn bộ nhớ là 64K nên ta dùng ba mảng động như sau: MG = array[-maxint..maxint] of byte;
L[1..3] of ^MG;
Xử lý trong hệ cơ số 100.
Chương trình.
{$A+,B-,D+,E+,F-,G-,I+,L+,N-,O-,P-,Q+,R+,S+,T-,V+,X+,Y+}
{$M 16384,0,655360}
program bai91;{Đỗ Đức Đông}
uses crt;
const fi ='input.txt';
 fo ='output.txt';
 coso =100;
type mg =array[-maxint..maxint]of byte;
var L :array[1..3]of ^mg;
 n,lap :longint;
 kq :integer;
 time :longint;
 clock :longint absolute $00:$0046c;
procedure tao_test;
var f :text;
 k :longint;
 begin
 n:=1000000;
 assign(f,fi);
 rewrite(f);
 writeln(f,n);
 for k:=1 to N do
 if random(2)=1 then write(f,random(maxint),#32)
 else write(f,-random(maxint),#32);
 close(f);
 end;
procedure danhdau(x:integer);
var i :integer;
 begin
 for i:=3 downto 1 do
 if L[i]^[x]<coso then
 begin
 inc(L[i]^[x]);
 break;
 end
 else L[i]^[x]:=0;
 end;
procedure lam;
var f :text;
 k :longint;
 x :integer;
 begin
 for k:=1 to 3 do
 begin
 new(L[k]);
 fillchar(L[k]^,sizeof(L[k]^),0);
 end;
 assign(f,fi);
 reset(f);
 read(f,n);
 for k:=1 to n do
 begin
 read(f,x);
 danhdau(x);
 end;
 close(f);
 lap:=0;
 for k:=-maxint to maxint do
 if L[1]^[k]*sqr(coso)+L[2]^[k]*coso+L[3]^[k]>lap then
 begin
 lap:=L[1]^[k]*sqr(coso)+L[2]^[k]*coso+L[3]^[k];
 kq:=k;
 end;
 for k:=1 to 3 do dispose(L[k]);
 end;
procedure ghif;
var f :text;
 begin
 assign(f,fo);
 rewrite(f);
 write(f,kq);
 writeln('So lan lap :',lap);
 close(f);
 end;
BEGIN
 {tao_test;}
 time:=clock;
 lam;
 ghif;
 writeln((clock-time)/18.2:10:10);
END.

File đính kèm:

  • docDe thi Toan Tin hoc trong nha truong Bai 91.doc