链表。若指针p指向某结点时,能够根据该指针找到其直接后继,能够顺后继指针链找到p结点后的结点。但是由于不知道其头指针,所以无法访问到p指针指向的结点的直接前趋。因此无法删去该结点。
2. 双链表。由于这样的链表提供双向指针,根据p结点的前趋指针和后继指针可以查找到其直接前趋和直接后继,从而可以删除该结点。其时间复杂度为O。
3. 单循环链表。根据已知结点位置,可以直接得到其后相邻的结点位置,又因为是循环链表,所以我们可以通过查找,得到p结点的直接前趋。因此可以删去p所指结点。其时间复杂度应为O。
2.6 下述算法的功能是什么?
LinkList Demo
return L;
}// Demo
答:
该算法的功能是:将开始结点摘下链接到终端结点之后成为新的终端结点,而原来的第二个结点成为新的开始结点,返回新链表的头指针。
2.7 设线性表的n个结点定义为,重写顺序表上实现的插入和删除算法:InsertList 和DeleteList.
解:算法如下:
#define ListSize 100 // 假定表空间大小为100
typedef int DataType;//假定DataType的类型为int型
typedef struct Seqlist;
//以上为定义表结构
void InsertList
void DeleteList
2.8 试分别用顺序表和单链表作为存储结构,实现将线性表就地逆置的操作,所谓"就地"指辅助空间应为O。
答:
1. 顺序表:
要将该表逆置,可以将表中的开始结点与终端结点互换,第二个结点与倒数第二个结点互换,如此反复,就可将整个表逆置了。算法如下:
// 顺序表结构定义同上题
void ReverseList
}
2. 链表:
分析:
可以用交换数据的方式来达到逆置的目的。但是由于是单链表,数据的存取不是随机的,因此算法效率太低。可以利用指针改指来达到表逆置的目的。具体情况入下:
当链表为空表或只有一个结点时,该链表的逆置链表与原表相同。
当链表含2个以上结点时,可将该链表处理成只含第一结点的带头结点链表和一个无头结点的包含该链表剩余结点的链表。然后,将该无头结点链表中的所有结点顺着链表指针,由前往后将每个结点依次从无头结点链表中摘下,作为第一个结点插入到带头结点链表中。这样就可以得到逆置的链表。算法是这样的:
结点结构定义如下:
typedef char DataType; //假设结点的数据域类型的字符
typedef struct nodeListNode;
typedef ListNode LinkList;
ListNode
LinkList head;
LinkList ReverseList
return head;
}
return head; //如是空表或单结点表,直接返回head
}