#include "intlist.h"
/* acyclic(x) and l[x]==_l and data(x) */
intlist listCopy(intlist x) {
intlist xi = x;
intlist y = NULL;
intlist yi = NULL;;
intlist z = NULL;
while (xi != NULL) {
z = new();
z->data = xi->data;
z->next = NULL;
if (y == NULL)
y = z;
else
yi->next = z;
yi = z;
xi = xi->next;
}
return y;
}
|
var _data:real, _free:real, _len:real,
_new:real, _next:real, _null:real,
x:real, xi:real, y:real, yi:real, z:real,
_l:int, _k:int, S: int;
begin
assume (x == 0);
xi = _null; z = _null;
yi = _null; y = _null;
xi = x;
while xi != _null do
z = _new;
z = (xi* _data)/ _data;
z = (_null)/_next;
if (y == _null) then
y = z;
else
yi = z / _next;
endif;
yi = _null;
yi = z;
z = _null;
z = xi * _next;
xi = _null;
xi = z;
z = _null;
done;
end
|