Autor Wiadomość
Ricko
PostWysłany: Pon 18:42, 14 Maj 2012    Temat postu: Matura 2011

Matura 2011

Część I

Treść:
Program pobiera liczbę sekund dziesiętnie i wypisuje ilość jedynek w przypadku zamiany na kod binarny:


Cytat:
program jedynki;

uses crt;

var
s,l:integer;

begin
clrscr;
writeln('Podaj liczbe sekund...');
readln(s);
l:=0;

while s>=1 do
begin
if s mod 2 = 1 then
l:=l+1;

s:=s div 2;
end;

writeln('Liczba jedynek to: ',l);
readln;
end.


Treść:
Program wypisuje TAK przypadku liczb pierwszych, a NIE w przypadku liczb złożonych

Cytat:
program pierw;

uses crt;

var
i,n:integer;

begin
clrscr;
readln(n);
i:=2;

repeat
begin
if n mod i = 0 then
begin
writeln('NIE');
break;
end
else
i:=i+1;
end;
until
i>=n;

if i = n then
writeln('TAK');
readln;
end.


Treść:
Rozkład danej liczby na czynniki pierwsze --> Zadanie z Matury 2010, gdzie trzeba było wypisywać dzielniki liczb:

Cytat:
program mat3;

uses crt;

var
n,i,j:integer;

begin
clrscr;
writeln('Podaj liczbe');
readln(n);

for i:=2 to n do
if n mod i = 0 then
begin
n:=n div i;
writeln(i);
i:=i-1;
end;
readln;
end.


Część II

Treść:
Program pobiera dane z pliku hasła.txt, następnie wykonuje 3 polecenia:
a)Sumuje parzyste i nieparzyste wyrazy i zapisuje je w pliku wyniki4a.txt
b)Znajduje palindromy i zapisuje je w pliku wyniki4b.txt
c)Wyszukuje hasła, w których sąsiednie litery zamienione w kodzie ASCII na liczby dają 220 i zapisuje je w pliku wyniki4c.txt

Cytat:
program hasla;

uses crt;

const
plik='hasla.txt';
wyn4a='wynik4a.txt';
wyn4b='wynik4b.txt';
wyn4c='wynik4c.txt';

var
i,parz,nieparz,d,l:integer;
s:string;
w1,w2,w3,p:text;

begin
clrscr;
assign(p,plik);
assign(w1,wyn4a);
assign(w2,wyn4b);
assign(w3,wyn4c);
reset(p);
rewrite(w1);
rewrite(w2);
rewrite(w3);
parz:=0;
nieparz:=0;

while not eof(p) do
begin
readln(p,s);

{parzyste i nieparzyste}
if length(s) mod 2 = 0 then
parz:=parz+1
else
nieparz:=nieparz+1;

{palindromy}
d:=length(s);
l:=0;
for i:=1 to d div 2 do
begin
if s[i]=s[d] then
begin
l:=l+1;
d:=d-1;
end;
end;
if l=length(s) div 2 then
writeln(w2,s);

{ascii}
for i:=1 to length(s)-1 do
if ord(s[i])+ord(s[i+1]) = 220 then
writeln(w3,s);

end;

writeln(w1,'Parzyste: ',parz);
writeln(w1,'Nieparzyste: ',nieparz);
writeln('Zapisano parzyste i nieparzyste');
writeln('Wykonano palindromy');
writeln('Wypisano hasla spelaniajce warunki ASCII');

close(w1);
close(w2);
close(w3);
close(p);

readln;
end.
Ricko
PostWysłany: Pią 22:07, 11 Maj 2012    Temat postu: Matura 2010

Matura 2010
Część I

Treść:
Mamy podany sposób opisujący pewną metodę szyfrowania, tworzymy do niego algorytm, pseudokod lub program:

Cytat:
program szyfr;

uses crt;

var
i,k,j:integer;
s,w:string;

begin
clrscr;
i:=1;
w:='';
k:=2;

writeln('Podaj slowo');
readln(s);

while i<=k do
begin
j:=i;

while j<=length(s) do
begin
w:=w+s[j];
j:=j+k;
end;

i:=i+1;
end;

writeln(w);
readln;
end.


Treść:
Mamy na podstawie podanego szyfrowania słów napisać program wykonujący taką samą czynność np. MATURA zamieniania jest na AMUTAR

Cytat:
program mat2;

uses crt;

var
s,w:string;
i:integer;

begin
clrscr;
w:='';

writeln('Podaj slowo');
readln(s);

for i:=1 to length(s) do

begin
if i=length(s) then
w:=w+s[i]
else
begin
w:=w+s[i+1]+s[i];
end;
i:=i+1;
end;

writeln(w);
readln;
end.


Treść:
Program ma za zadanie wypisywać wszystkie dzielniki podanej liczby:

Cytat:
program mat3;

uses crt;

var
n,i,j:integer;

begin
clrscr;
writeln('Podaj liczbe');
readln(n);

for i:=2 to n do
if n mod i = 0 then
begin
n:=n div i;
writeln(i);
i:=i-1;
end;
readln;
end.


Część II

Treść:
Program pobiera dane z pliku, sprawdza czy słowa są palindromami i te, które spełniają warunek zapisuje do pliku

Cytat:
program pal;

uses crt;

const
plik='dane2.txt';
plik2='zadanie4.txt';

var
F,F2:text;
i,d,l:integer;
slowo:string;

begin
clrscr;
assign(F,plik);
assign(F2,plik2);
reset(F);
rewrite(F2);
while not eof(F) do
begin
readln(F,slowo);
d:=length(slowo);
l:=0;
for i:=1 to length(slowo) div 2 do
if slowo[i]=slowo[d] then
begin
l:=l+1;
d:=d-1;
end;

if l=length(slowo) div 2 then
begin
writeln(slowo);
writeln(F2,slowo);
end;
end;
readln;
close(F);
close(F2);
end.
Ricko
PostWysłany: Pią 22:05, 11 Maj 2012    Temat postu: Matura z Informatyki - Zadania

Matura 2009
Cześć I
Treść:
Wykonanie programu na podstawie podanego algorytmu [Wyniki rzutu oszczepem]. Program wypisze TAK tylko w wypadku, gdy każdy rzut jest dłuższy od poprzedniego, w innym wypadku zostanie wypisane NIE:

Cytat:
program wyniki;

uses crt;

const
n=8;

var
t:array[1..n]of real;
akt,nast:real;
i:integer;

begin
clrscr;
t[1]:=60.51;
t[2]:=61.34;
t[3]:=61.85;
t[4]:=61.97;
t[5]:=62.79;
t[6]:=63.00;
t[7]:=63.81;
t[8]:=63.88;
akt:=t[1];
for i:=1 to n do
begin
nast:=t[i+1];

if i=n then
begin
writeln('TAK');
break;
end;

if nast>akt then
akt:=nast
else
begin
writeln('NIE');
break;
end;
end;
readln;
end.


Treść:
Modyfikacja poprzedniego zadania polegająca na wypisywaniu największego wyniku:

Cytat:
program maxwyn;

uses crt;

const
n=8;

var
t:array[1..n]of real;
akt,nast,max:real;
i:integer;

begin
clrscr;
t[1]:=60.51;
t[2]:=61.34;
t[3]:=61.85;
t[4]:=61.97;
t[5]:=62.79;
t[6]:=63.00;
t[7]:=63.81;
t[8]:=63.88;
max:=0;
for i:=1 to n do
begin
if t[i]>max then
max:=t[i];
end;
writeln(max);
readln;
end.


Treść:
Program zamieniające kwoty dwójkowe na dziesiętne (razem z groszami):

Cytat:
program sklep;

uses crt;

var
s,suma:string;
i,j,k,zl,gr,p:integer;

begin
clrscr;
writeln('Podaj kwote binarnie');
readln(s);
for i:=1 to length(s) do
if (s[i]=',') OR (s[i]='.') then
begin
k:=i;
break;
end
else
k:=length(s)+1;

if s[k-1]='1' then
zl:=zl+1;

for i:=k-2 downto 1 do
if s[i]='1' then
begin
p:=1;
j:=k-1-i;
repeat
begin
p:=p*2;
j:=j-1;
end;
until
j=0;
zl:=zl+p;
end;

if k<>length(s)+1 then
begin
if s[length(s)-1]='1' then
gr:=50;

if s[length(s)]='1' then
gr:=gr+25
end;

writeln('Podana kwota dziesietnie to: ',zl,',',gr);

readln;
end.


Część II

Treść:
Program ma zadanie wczytać liczby z pliku i wyszukać te, które są kwadratami liczb pierwszych

Cytat:
program pierwsze;

uses crt;

const
plik='liczby.txt';

var
f:text;
i,k:integer;
liczba,n:longint;

begin
clrscr;
assign(f,plik);
reset(f);
writeln('Wczytywanie liczb z pliku');
while not eof(f) do
begin
read(f,liczba);
n:=round(sqrt(liczba));
if n*n = liczba then
begin
k:=0;
for i:=1 to n do
begin
if n mod i = 0 then
k:=k+1;
end;

if k=2 then
writeln(liczba);
end;
end;;
readln;
end.

Powered by phpBB © 2001,2002 phpBB Group