一、删除单链表的非尾节点ide
解题思路:按照通常的思路单链表删除节点是必须知道其前驱节点才能删除,而在本题中不知道前驱节点,因此转换思路,先将须要删除的节点跟其后继节点的数据域交换,而后再删除既可。排序
void EraseNotTail(pLinkNode pos) { assert(pos); pLinkNode del = NULL;//删除的节点 del = pos->next; pos->data = pos->next->data; pos->next = pos->next->next; free(del); del = NULL; }
二、冒泡排序单链表it
void BubbleSort(pList * pHead) { pLinkNode cur = *pHead; pLinkNode end = NULL; int change = 1; assert(pHead); if (*pHead == NULL) { return; } else if (cur->next == NULL) { return; } while ((cur != end)&&(change))//控制排序几轮 { change = 0; while ((cur)&&(cur->next != end))//排序 { change = 1; if (cur->data > cur->next->data) { DataType tmp = cur->data; cur->data = cur->next->data; cur->next->data = tmp; } cur = cur->next; } end = cur; cur = *pHead;//使得单链表从头开始 } }
三、在当前节点前插入一个数据xclass
思路解析:按照通常的思路其应该须要找到节点的前驱节点,才能插入,可是能够换一个思路,能够先把节点插入到其后方,而后再将两个节点的数据域进行交换便可很好的解决该问题。List
void InsertFrontNode(pLinkNode pos, DataType x) { pLinkNode newNode = BuyNode(x); assert(pos); newNode->next = pos->next; pos->next = newNode; DataType tmp = pos->data; pos->data = pos->next->data; pos->next->data = tmp; }