4-6 带头结点的链式表操作集
code:
List MakeEmpty()
{
List L;
L = (List)malloc(sizeof(struct LNode));
L->Data = NULL;
L->Next = NULL;
return L;
}
Position Find( List L, ElementType X )
{
List p = L;
while(p && p->Data!=X) {
p = p->Next;
}
if(p && X==p->Data) {
return p;
} else {
return ERROR;
}
}
bool Insert( List L, ElementType X, Position P )
{
List r = L;
List pre = L;
while(r && P!=r) {
pre = r;
r = r->Next;
}
if(r==P) {
List p = (List)malloc(sizeof(struct LNode));
p->Data = X;
p->Next = r;
pre->Next = p;
return true;
}
printf("Wrong Position for Insertion\n");
return false;
}
bool Delete( List L, Position P )
{
List r = L;
List pre = L;
while(r && r!=P)
{
pre = r;
r = r->Next;
}
if(r==P) {
pre->Next = P->Next;
free(P);
List k = pre->Next;
return true;
}
printf("Wrong Position for Deletion\n");
return false;
}
P.S:这道题需要写四个函数,分别是链表的置空,查询某个元素,还有元素的插入和删除,都是一些链表的基本操作,题中的链表是有头节点的,而开始的题中的链表是没有使用头节点的,这个与前面的有一些区别,其实拥有头节点的链表更容易操作,在插入时不用考虑是否是第一个结点了,更加好写些,同样要注意Find函数,它需要返回的是这个元素的Position,而它是一个指针变量,而不是代表其位置的整型变量。
4-7 在一个数组中实现两个堆栈
P.S:很头疼,这一题没有通过,报的错误也是十分无奈,超时,所以也不知道怎样去解决这个问题,如何去优化代码,这道题其实是一个数组嘛,两个栈的栈底在两头,设计应该就是这样,但是给我报超时错误,暂时先放下吧,以后通过再补上来。
更新:补上成功的code,今天突然再次提交,居然就通过了,看来我的想法是没有问题的^_^
code:
Stack CreateStack( int MaxSize )
{
Stack S = (Stack)malloc(sizeof(struct SNode));
S->MaxSize = MaxSize;
S->Data = (ElementType *)malloc(sizeof(ElementType)*MaxSize);
S->Top2 = MaxSize;
S->Top1 = -1;
return S;
}
bool Push(Stack S, ElementType X, int Tag){
if(S->Top1+1 == S->Top2){
printf("Stack Full\n");
return false;
}else{
if(Tag == 1){
S->Top1++;
S->Data[S->Top1] = X;
}else{
S->Top2--;
S->Data[S->Top2] = X