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 |
|
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 |
|