PASCAL中怎么建立一个双向的链表
答案:3 悬赏:60 手机版
解决时间 2021-02-28 11:39
- 提问者网友:风月客
- 2021-02-28 01:21
PASCAL中怎么建立一个双向的链表
最佳答案
- 五星知识达人网友:毛毛
- 2021-02-28 02:08
type pointer=^node;
node=record
data:integer;
front,next:pointer;
end;
var head,tail:pointer; n:integer;
procedure creat(var head,tail:pointer; var n:integer); {jianli caozuo}
var p:pointer;
begin
n:=0; new(p);
readln(p^.data); p^.front:=nil; p^.next:=nil;
while p^.data<>-1 do
begin inc(n);
if n=1 then begin head:=p; tail:=p; end
else begin p^.front:=tail; tail^.next:=p; p^.next:=nil;
tail:=p; end;
new(p);
readln(p^.data);
end;end;
procedure print(head,tail:pointer);
var p:pointer;
begin
p:=head;
writeln('tou dao wei:');
while p<>nil do
begin
write(p^.data:6);
p:=p^.next;
end;
writeln;
end;
begin
creat(head,tail,n);
print(head,tail);
dele(head,tail,n,2);
print(head,tail);
end.
node=record
data:integer;
front,next:pointer;
end;
var head,tail:pointer; n:integer;
procedure creat(var head,tail:pointer; var n:integer); {jianli caozuo}
var p:pointer;
begin
n:=0; new(p);
readln(p^.data); p^.front:=nil; p^.next:=nil;
while p^.data<>-1 do
begin inc(n);
if n=1 then begin head:=p; tail:=p; end
else begin p^.front:=tail; tail^.next:=p; p^.next:=nil;
tail:=p; end;
new(p);
readln(p^.data);
end;end;
procedure print(head,tail:pointer);
var p:pointer;
begin
p:=head;
writeln('tou dao wei:');
while p<>nil do
begin
write(p^.data:6);
p:=p^.next;
end;
writeln;
end;
begin
creat(head,tail,n);
print(head,tail);
dele(head,tail,n,2);
print(head,tail);
end.
全部回答
- 1楼网友:雪起风沙痕
- 2021-02-28 03:20
var
i,j,n:longint;
pre,now,x,y:array[0..1000] of longint;begin
readln(n);
for i:=1 to n do
begin
readln(x[i*2-1],y[i*2-1]);
pre[i*2-1]:=now[x[i*2-1]];
now[x[i*2-1]]:=i*2-1; x[i*2]:=y[x*2-1]; y[x*2]:=x[i*2-1];
pre[i*2]:=now[x[i*2]];
now[x[i*2]]:=i*2;
end;
end. 是这样的吗?
i,j,n:longint;
pre,now,x,y:array[0..1000] of longint;begin
readln(n);
for i:=1 to n do
begin
readln(x[i*2-1],y[i*2-1]);
pre[i*2-1]:=now[x[i*2-1]];
now[x[i*2-1]]:=i*2-1; x[i*2]:=y[x*2-1]; y[x*2]:=x[i*2-1];
pre[i*2]:=now[x[i*2]];
now[x[i*2]]:=i*2;
end;
end. 是这样的吗?
- 2楼网友:千夜
- 2021-02-28 02:47
指针实现的双向链表:
type
node = ^list;
list = record
val:integer;
prev,next:node;
end;
{尾部插入}
procedure append(var head:node; val:integer);
var
p,t:node;
begin
t := head;
p := nil;
while t <> nil do
begin p := t; t := t^.next; end;
if p <> nil then
begin new(p^.next); t := p^.next end
else
begin new(head); t := head; end;
t^.prev := p;
t^.next := nil;
t^.val := val;
end;
{遍历输出}
procedure traversal(head:node);
begin
while head <> nil do
begin
write(head^.val, ' ');
head := head^.next;
end;
writeln;
end;
{反序}
procedure reverse(var head:node);
var l,t:node;
begin
l := head;
while l <> nil do
begin
t := l^.next;
l^.next := l^.prev;
l^.prev := t;
head := l;
l := t;
end;
end;
{销毁}
procedure destroy(head:node);
var t:node;
begin
while head <> nil do
begin
t := head;
head := head^.next;
dispose(t);
end;
end;
var
head:node = nil;
i:integer;
begin
for i := 1 to 10 do
append(head, i);
traversal(head);
reverse(head);
traversal(head);
destroy(head);
readln;
end.
type
node = ^list;
list = record
val:integer;
prev,next:node;
end;
{尾部插入}
procedure append(var head:node; val:integer);
var
p,t:node;
begin
t := head;
p := nil;
while t <> nil do
begin p := t; t := t^.next; end;
if p <> nil then
begin new(p^.next); t := p^.next end
else
begin new(head); t := head; end;
t^.prev := p;
t^.next := nil;
t^.val := val;
end;
{遍历输出}
procedure traversal(head:node);
begin
while head <> nil do
begin
write(head^.val, ' ');
head := head^.next;
end;
writeln;
end;
{反序}
procedure reverse(var head:node);
var l,t:node;
begin
l := head;
while l <> nil do
begin
t := l^.next;
l^.next := l^.prev;
l^.prev := t;
head := l;
l := t;
end;
end;
{销毁}
procedure destroy(head:node);
var t:node;
begin
while head <> nil do
begin
t := head;
head := head^.next;
dispose(t);
end;
end;
var
head:node = nil;
i:integer;
begin
for i := 1 to 10 do
append(head, i);
traversal(head);
reverse(head);
traversal(head);
destroy(head);
readln;
end.
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯