procedure und function < Pascal < Programmiersprachen < Praxis < Informatik < Vorhilfe
|
Status: |
(Frage) beantwortet | Datum: | 13:52 Di 28.03.2006 | Autor: | DAB268 |
Hallo.
Wäre eine function, die z.B. ei Element in eine Liste einfügt, nicht das selbe wie eine proedure, die dies tut? Jedenfalls, wenn ich immer auf der selben Liste arbeiten will. Möchte ich diese Liste kopieren und ein Element einfügen, brauche ich dann die Funktion copy oder kann ich auch sagen l2:=add(l1,x); gennode erstellt einen neuen Knoten der Form(Wert, Restliste)
Hier noch die Funktionen und Prozeduren.
function add(l:list, ax:integer):list
begin
if l=nil, then add:=gennode(ax,nil)
else
begin
add:=l;
l^.next:=add(l^.next, ax);
end;
end;
procedure add(var l:list; ax:integer)
begin
if l=nil then add:=gennode(ax,nil)
else
begin
add:=l;
l^.next:=add(l, ax);
end;
end;
function copy(l:list):list
begin
if l=nil then copy:=nil
else
begin
copy:=l;
l^.next:=gennode(l^.x,copy(l^.next));
end;
end;
|
|
|
|
Hallo,
der Unterschied zwischen proceduren und functionen ist, dass eine Funktion einen Wert zurückgeben kann, eine Prozedur nicht. So wäre in deiner Prozedur add die Zuweisung l^.next := add(..., ...); nicht gültig, da add keine Funktion ist, somit nicht in einem Ausdruck vorkommen darf, sondern nur als "Statement"/Anweisung erfolgen darf.
Du kannst Dir ja mal überlegen, worin das Problem liegt, dass genau eine Funktion verwendet wird. "VAR" parameter sind die Lösung für dieses Problem, falls es denn umbedingt eine Prozedur sein soll. Meiner Meinung nach wäre das auch schöner, da die Signatur der Funktion add suggerieren könnte, dass man eine neue Liste bekommt, dies ist aber nicht der Fall.
--
Gruß
Matthias
|
|
|
|
|
Status: |
(Mitteilung) Reaktion unnötig | Datum: | 14:34 Di 28.03.2006 | Autor: | DAB268 |
Danke! Habe wohl nicht tief genug in die Funktion geschaut :-/
|
|
|
|