Mihai Sprinceana
Un forum de programare cu de toate. Va astept sa va inscrieti si sa deveniti moderatori. Oricine este binevenit aici sa se inscrie si sa aiba acces la informatie free! Fiecare este liber sa adauge proiecte programe free etc. Ajutati acest forum sa devina o comunitate puternica unde fiecare invata de la fiecare! Tot ce trebuie sa faceti este sa va inregistrati si fiecare contributie se poate dovedi utila in timp! Forumul este free informatia free dk aveti timp liber ajutati si pe ceilalti si invatati si voi in acelasi timp! Haideti sa facem ceva pt.a ne ajuta intre noi! Cititi regulament postare forum inainte de a posta!
Lista Forumurilor Pe Tematici
Mihai Sprinceana | Inregistrare | Login

POZE MIHAI SPRINCEANA

Nu sunteti logat.
Nou pe simpatie:
AlexandraPopa la Simpatie.ro
Femeie
25 ani
Bucuresti
cauta Barbat
25 - 39 ani
Mihai Sprinceana / Pascal / Problema vectori: v34.pas Moderat de Houssey, cosmin, cosmy, fireratbat, profu.info, sade5000
Autor
Mesaj Pagini: 1
Houssey
Moderator

Din: Buzau
Inregistrat: acum 17 ani
Postari: 260
{ Se da un vector de numere intregi si o  valoare naturala, V.
Sa se realizeze o operatie de cautare completa a lui V in vector ( exista
sau nu, numarul de aparitii, pozitia primei aparitii, pozitia ultimei
aparitii si celelalte aparitii ).
Ex: vectorul este ( 1,2,2,4,,2,5,2,5,2) si V=2 ( Valoarea 2 apare de 5 ori)
    Prima data apere pe poz. 2
    Ultima  data apare pe pozitia 9
    Celelalte aparitii sunt pe pozitiile : 3,5,7}
type vector=array[1..100] of integer;
var v:vector;
    na,i,n,a,b,z:integer;
procedure citire;
begin
for i:=1 to n do begin
    write('v[',i,']=');readln(v[i]);
                 end;
end;
procedure afisare;
begin
for i:=1 to n do begin
    write(v[i],' ');
    writeln;
                 end;
end;
function cautare(var x:vector;k,m:integer):boolean;
var s:boolean;
begin
s:=false;
i:=1;
while not s and (i<=k) do
      if x[i]=m then s:=true
                else i:=i+1;
cautare:=s;
end;
function apar(var x:vector;k,m:integer):integer;
var c:integer;
begin
c:=0;
for i:=1 to k do if x[i]=m then c:=c+1;
apar:=c;
end;
function prima(var x:vector;k,m:integer):integer;
var p:integer;
begin
p:=0;
i:=1;
while (i<=k) and (p=0) do
    if x[i]=m then p:=i
              else i:=i+1;
prima:=p;
end;
function ultima(var x:vector;k,m:integer):integer;
var u:integer;
begin
u:=0;
i:=n;
while (i>=1) and (u=0) do
if x[i]=m then u:=i
           else i:=i-1;
ultima:=u;
end;
begin
repeat
  write('n=');readln(n);
until (n>0) and (n<=100);
write('numarul care se cauta este=');readln(z);
citire;
afisare;
if cautare(v,n,z) then begin writeln('s-a gasit numarul ',z);
                             na:=apar(v,n,z);
                             writeln('nr ',z,' apare de ',na,' ori');
                             a:=prima(v,n,z);
                             b:=ultima(v,n,z);
                             if na=1 then writeln('nr ',z,' apare o singura data pe pozitia ',prima(v,n,z))
                                     else begin writeln('prima aparitie a nr. ',z,' este pe pozitia ',prima(v,n,z));
                                                writeln('ultima aparitie a nr. ',z,' este pe pozitia ',ultima(v,n,z));
                             if na>2 then begin writeln('celelalte aparitii ale cifrei ',z,' sunt pe pozitiile:');
                                for i:=1 to n do
                                    if v[i]=z then if (i<>a) and (i<>b) then write(i,' ');writeln;
                                          end;
                                           end;
                       end;
readln;readln;
end.


_______________________________________
House Music Set`s Me Free!

pus acum 16 ani
   
Pagini: 1  

Mergi la