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:
andrum94
Femeie
25 ani
Galati
cauta Barbat
27 - 80 ani
Mihai Sprinceana / Pascal / Adunarea si inmultirea polinoamelor Moderat de Houssey, cosmin, cosmy, fireratbat, profu.info, sade5000
Autor
Mesaj Pagini: 1
meredith
Membru nou

Inregistrat: acum 16 ani
Postari: 2
Buna.Ma puteti ajuta si pe mine cu un program care realizeaza adunarea si inmultirea polinoamelor folosind tabloul(lista) termenilor.Teoretic stiu cum se rezolva,dar practica este mai grea. Va multumesc.

pus acum 16 ani
   
cosmy
Moderator

Inregistrat: acum 16 ani
Postari: 33
{adunarea a 2 polinoame date in ordinea descrescatoare a gradelor}
type lista=^nod;
     nod=record
       coef:integer;
       grad:integer;
       leg:lista;
     end;
var l1,l2,l3:lista;
    n1,n2:integer;

function creare(var x:integer):lista;
var p,nou,prim,ultim:lista;
    n,i:integer;
begin
n:=x;
new(prim);
write('gradul: ');readln(prim^.grad);
write('coeficientul: ');readln(prim^.coef);
ultim:=prim;
for i:=2 to n do
  begin
  new(p);
  write('gradul: ');readln(p^.grad);
  write('coeficientul: ');readln(p^.coef);
  p^.leg:=nil;
  ultim^.leg:=p;
  ultim:=p;
  end;
creare:=prim;
end;

function adunare(r,q:lista):lista;
var p,prim,ultim:lista;
    j,k:integer;
begin
j:=1;k:=1;
if ((r<>nil)and(q<>nil))  then begin
                          new(prim);
                          if (r^.grad>q^.grad) then begin
                                               prim^.grad:=r^.grad;
                                               prim^.coef:=r^.coef;
                                               r:=r^.leg;inc(j);
                                               end
                          else if (r^.grad<q^.grad)  then begin
                                               prim^.grad:=q^.grad;
                                               prim^.coef:=q^.coef;
                                               q:=q^.leg;inc(k);
                                               end
                            else begin
                                 prim^.grad:=r^.grad;
                                 prim^.coef:=r^.coef+q^.coef;
                                 r:=r^.leg;q:=q^.leg; inc(j);inc(k);
                                 end;
                            ultim:=prim;
                            end;
while ((r<>nil) and (q<>nil)) do begin
new(p);
if (r^.grad>q^.grad) then begin
                      p^.grad:=r^.grad;
                      p^.coef:=r^.coef;
                      r:=r^.leg;inc(j);
                      end
          else if(p^.grad<q^.grad) then begin
                                    p^.grad:=q^.grad;
                                    p^.coef:=q^.coef;
                                    q:=q^.leg;inc(k);
                                    end
                            else begin
                                 p^.grad:=r^.grad;
                                 p^.coef:=r^.coef+q^.coef;
                                 r:=r^.leg;q:=q^.leg;
                                 inc(j);inc(k);
                                 end;
p^.leg:=nil;
  ultim^.leg:=p;
  ultim:=p;
  end;
if ((q<>nil) and (r=nil)) then
while (k<=n2) do
    begin
    new(p);
    p^.grad:=q^.grad;
    p^.coef:=q^.coef;
    q:=q^.leg;
    p^.leg:=nil;inc(k);
  ultim^.leg:=p;
  ultim:=p;
  end;
if((r<>nil) and (q=nil)) then
while (j<=n1) do
  begin
  new(p);
  p^.grad:=r^.grad;
  p^.coef:=r^.coef;
  r:=r^.leg;
  p^.leg:=nil;inc(j);
  ultim^.leg:=p;
  ultim:=p;
  end;
adunare:=prim;
end;

procedure afisare(p:lista);
begin
while p^.leg<>nil do
  begin
  write(p^.coef,'X la puterea',p^.grad,'+');
  p:=p^.leg;
  end;
write(p^.coef,'X la puterea',p^.grad,'=0');
p:=p^.leg;
writeln;
end;

begin
write('n1= ');readln(n1);
l1:=creare(n1);afisare(l1);
write('n2= ');readln(n2);
l2:=creare(n2);
afisare(l2);
l3:=adunare(l1,l2);
afisare(l3);
end.


pus acum 16 ani
   
meredith
Membru nou

Inregistrat: acum 16 ani
Postari: 2
Multumesc mult de tot

pus acum 16 ani
   
Pagini: 1  

Mergi la