C++实现单链表(2) 一些函数的实现
来源:互联网 发布:一核有难九核围观 知乎 编辑:程序博客网 时间:2024/06/03 23:39
void PrintTailtoHead(ListNode * pHead) //逆向输出链表
{
if (pHead == NULL)
{
return;
}
else
{
PrintTailtoHead(pHead->_next);
printf("%d->", pHead->_data);
}
/*
if(pHead)
{
PrintTailtoHead(pHead->_next);
printf("%d->", pHead->_data);
}
*/
}
ListNode * SearchMidNode(ListNode * pHead) //寻找中间结点
{
ListNode * fast = pHead, *slow = pHead;
assert(pHead);
while (fast!=NULL && fast->_next != NULL)
{
fast = fast->_next;
slow = slow->_next;
fast = fast->_next;
}
return slow; //如果是一个结点直接返回slow
}
void PrevInsert(ListNode* &pos, DataType x) //无头链表的前插 先后插再交换数据
{
assert(pos);
ListNode *tmp = BuyNode(x);
tmp->_next = pos->_next;
pos->_next = tmp;
//利用没有用的x 节省空间
x = pos->_data;
pos->_data = tmp->_data;
tmp->_data = x;
/*
assert(pos);
ListNode *tmp = BuyNode(pos->_data);
tmp->_next = pos->_next;
pos->_next = tmp;
//利用没有用的x 节省空间
pos->_data=x;
*/
}
//链表冒泡排序
void BubbleSort(ListNode * pHead)
{
ListNode * post = NULL; //设置监视哨
ListNode * cur = pHead;
int flag = 0;
if (cur == NULL||cur->_next==NULL)
return;
while (1)
{
cur = pHead;
flag = 0;
while (cur->_next != post)
{
if (cur->_data > cur->_next->_data)
{
//交换
flag = 1;
DataType tmp = cur->_data;
cur->_data = cur->_next->_data;
cur->_next->_data = tmp;
}
cur = cur->_next;
}
post = cur;
if (!flag||post==pHead)
break;
}
}
//归并排序
ListNode * MergeList(ListNode * pHead1, ListNode * pHead2)
{
ListNode *pList1Cur=pHead1, *pList2Cur=pHead2;
if (pHead1 == NULL)
return pHead2;
if (pHead2 == NULL)
return pHead2;
ListNode * newHead;
if (pHead1->_data <= pHead2->_data)
{
newHead = pHead1;
pList1Cur = pList1Cur->_next;
}
else
{
newHead = pHead2;
pList2Cur = pList2Cur->_next;
}
ListNode* tail = newHead;
while (pList1Cur&&pList2Cur)
{
if (pList1Cur->_data < pList2Cur->_data)
{
tail->_next = pList1Cur;
pList1Cur = pList1Cur->_next;
}
else
{
tail->_next = pList2Cur;
pList2Cur = pList2Cur->_next;
}
tail = tail->_next;
}
if (pList1Cur!=NULL)
{
tail->_next = pList1Cur;
}
else
{
tail->_next = pList2Cur;
}
return newHead;
}
ListNode * FindTailNode(ListNode * pHead, int k) //寻找倒数第k个结点
{
ListNode * fast = pHead, *slow = pHead;
int count = k;
while (count--)
{
if (fast == NULL)
return NULL;
fast = fast->_next;
}
while (fast != NULL)
{
fast = fast->_next;
slow = slow->_next;
}
return slow;
}
//判断一个单链表带环 注意不要出现NULL==NULL这种情况
//快慢指针解决
int IsCycle(ListNode *pHead) //带环返回1 不带环返回0 错误返回-1
{
ListNode *fast = pHead, *slow = pHead; //快慢指针
if (pHead == NULL)
return -1;
fast = fast->_next->_next;
slow = slow->_next;
while (fast != NULL&&fast->_next != NULL&&fast != slow)
{
fast = fast->_next->_next;
slow = slow->_next;
}
if (fast == slow)
return 1;
else
return 0;
}
//带环则环中的一个结点指针 不带环返回NULL 判断是否有环的另一个版本
ListNode* IsCycle2(ListNode *pHead)
{
ListNode *fast = pHead, *slow = pHead; //快慢指针
if (pHead == NULL)
return NULL;
fast = fast->_next->_next;
slow = slow->_next;
while (fast != NULL&&fast->_next != NULL&&fast != slow)
{
fast = fast->_next->_next;
slow = slow->_next;
}
if (fast == slow)
return fast;
else
return NULL;
}
int CycleLength(ListNode *pHead) //返回环的长度 没有环返回0 有环返回 1 - n
{
ListNode *fast = pHead, *slow = pHead; //快慢指针
if (pHead == NULL)
return -1;
fast = fast->_next->_next;
slow = slow->_next;
while (fast != NULL&&fast->_next != NULL&&fast != slow)
{
fast = fast->_next->_next;
slow = slow->_next;
}
if (fast == slow)
{
ListNode *sign = fast;
int count = 0;
fast = fast->_next;
while (sign != fast)
{
count++;
fast = fast->_next;
}
return count+1;
}
return 0;
}
//另一个版本的求环长度的函数
int CycleLength2(ListNode *pHead)
{
ListNode * node = IsCycle2(pHead);
if (node == NULL)
return 0;
else
{
int count = 0;
ListNode * tmp = node->_next;
while (tmp != node)
{
count++;
tmp = tmp->_next;
}
return count + 1;
}
}
ListNode * Entrance(ListNode *pHead) //求环入口的结点 返回指向入口结点的指针
{
ListNode * entrance = NULL; //返回值
//首先先找到环的一个指针 把它当作一个链表的头
ListNode* CycleHead = IsCycle2(pHead);
//然后求这个“链表”和pHead两个的交点即可
//当然,不能用写好的判断一般链表是否相交的函数 因为链表没有尾
//大前提是已经有环了 若无环返回NULL
ListNode * cur1 = pHead, *cur2 = CycleHead;
//这样做费时
while (cur1 != cur2&&cur1!=NULL)
{
int len = CycleLength2(CycleHead); //获取环长度
while (cur1 != cur2&&len--)
{
cur2 = cur2->_next;
}
if (cur1 == cur2)
return cur1;
else
cur1 = cur1->_next;
}
if (cur1 == cur2)
return cur1;
return NULL;
}
//判断两个链表是否相交
int IsIntersect(ListNode* pHead1, ListNode* pHead2)
{
ListNode * cur1 = pHead1, *cur2 = pHead2;
ListNode * prevCur1=pHead1,* prevCur2=pHead2;
if (cur1 == NULL)
return 0;
if (cur2 == NULL)
return 0;
while (cur1 != NULL&&cur2 != NULL&&prevCur1!=prevCur2)
{
prevCur1 = cur1;
prevCur2 = cur2;
cur1 = cur1->_next;
cur2 = cur2->_next;
}
if (prevCur1 == prevCur2)
return 1;
else
return 0;
}
{
if (pHead == NULL)
{
return;
}
else
{
PrintTailtoHead(pHead->_next);
printf("%d->", pHead->_data);
}
/*
if(pHead)
{
PrintTailtoHead(pHead->_next);
printf("%d->", pHead->_data);
}
*/
}
ListNode * SearchMidNode(ListNode * pHead) //寻找中间结点
{
ListNode * fast = pHead, *slow = pHead;
assert(pHead);
while (fast!=NULL && fast->_next != NULL)
{
fast = fast->_next;
slow = slow->_next;
fast = fast->_next;
}
return slow; //如果是一个结点直接返回slow
}
void PrevInsert(ListNode* &pos, DataType x) //无头链表的前插 先后插再交换数据
{
assert(pos);
ListNode *tmp = BuyNode(x);
tmp->_next = pos->_next;
pos->_next = tmp;
//利用没有用的x 节省空间
x = pos->_data;
pos->_data = tmp->_data;
tmp->_data = x;
/*
assert(pos);
ListNode *tmp = BuyNode(pos->_data);
tmp->_next = pos->_next;
pos->_next = tmp;
//利用没有用的x 节省空间
pos->_data=x;
*/
}
//链表冒泡排序
void BubbleSort(ListNode * pHead)
{
ListNode * post = NULL; //设置监视哨
ListNode * cur = pHead;
int flag = 0;
if (cur == NULL||cur->_next==NULL)
return;
while (1)
{
cur = pHead;
flag = 0;
while (cur->_next != post)
{
if (cur->_data > cur->_next->_data)
{
//交换
flag = 1;
DataType tmp = cur->_data;
cur->_data = cur->_next->_data;
cur->_next->_data = tmp;
}
cur = cur->_next;
}
post = cur;
if (!flag||post==pHead)
break;
}
}
//归并排序
ListNode * MergeList(ListNode * pHead1, ListNode * pHead2)
{
ListNode *pList1Cur=pHead1, *pList2Cur=pHead2;
if (pHead1 == NULL)
return pHead2;
if (pHead2 == NULL)
return pHead2;
ListNode * newHead;
if (pHead1->_data <= pHead2->_data)
{
newHead = pHead1;
pList1Cur = pList1Cur->_next;
}
else
{
newHead = pHead2;
pList2Cur = pList2Cur->_next;
}
ListNode* tail = newHead;
while (pList1Cur&&pList2Cur)
{
if (pList1Cur->_data < pList2Cur->_data)
{
tail->_next = pList1Cur;
pList1Cur = pList1Cur->_next;
}
else
{
tail->_next = pList2Cur;
pList2Cur = pList2Cur->_next;
}
tail = tail->_next;
}
if (pList1Cur!=NULL)
{
tail->_next = pList1Cur;
}
else
{
tail->_next = pList2Cur;
}
return newHead;
}
ListNode * FindTailNode(ListNode * pHead, int k) //寻找倒数第k个结点
{
ListNode * fast = pHead, *slow = pHead;
int count = k;
while (count--)
{
if (fast == NULL)
return NULL;
fast = fast->_next;
}
while (fast != NULL)
{
fast = fast->_next;
slow = slow->_next;
}
return slow;
}
//判断一个单链表带环 注意不要出现NULL==NULL这种情况
//快慢指针解决
int IsCycle(ListNode *pHead) //带环返回1 不带环返回0 错误返回-1
{
ListNode *fast = pHead, *slow = pHead; //快慢指针
if (pHead == NULL)
return -1;
fast = fast->_next->_next;
slow = slow->_next;
while (fast != NULL&&fast->_next != NULL&&fast != slow)
{
fast = fast->_next->_next;
slow = slow->_next;
}
if (fast == slow)
return 1;
else
return 0;
}
//带环则环中的一个结点指针 不带环返回NULL 判断是否有环的另一个版本
ListNode* IsCycle2(ListNode *pHead)
{
ListNode *fast = pHead, *slow = pHead; //快慢指针
if (pHead == NULL)
return NULL;
fast = fast->_next->_next;
slow = slow->_next;
while (fast != NULL&&fast->_next != NULL&&fast != slow)
{
fast = fast->_next->_next;
slow = slow->_next;
}
if (fast == slow)
return fast;
else
return NULL;
}
int CycleLength(ListNode *pHead) //返回环的长度 没有环返回0 有环返回 1 - n
{
ListNode *fast = pHead, *slow = pHead; //快慢指针
if (pHead == NULL)
return -1;
fast = fast->_next->_next;
slow = slow->_next;
while (fast != NULL&&fast->_next != NULL&&fast != slow)
{
fast = fast->_next->_next;
slow = slow->_next;
}
if (fast == slow)
{
ListNode *sign = fast;
int count = 0;
fast = fast->_next;
while (sign != fast)
{
count++;
fast = fast->_next;
}
return count+1;
}
return 0;
}
//另一个版本的求环长度的函数
int CycleLength2(ListNode *pHead)
{
ListNode * node = IsCycle2(pHead);
if (node == NULL)
return 0;
else
{
int count = 0;
ListNode * tmp = node->_next;
while (tmp != node)
{
count++;
tmp = tmp->_next;
}
return count + 1;
}
}
ListNode * Entrance(ListNode *pHead) //求环入口的结点 返回指向入口结点的指针
{
ListNode * entrance = NULL; //返回值
//首先先找到环的一个指针 把它当作一个链表的头
ListNode* CycleHead = IsCycle2(pHead);
//然后求这个“链表”和pHead两个的交点即可
//当然,不能用写好的判断一般链表是否相交的函数 因为链表没有尾
//大前提是已经有环了 若无环返回NULL
ListNode * cur1 = pHead, *cur2 = CycleHead;
//这样做费时
while (cur1 != cur2&&cur1!=NULL)
{
int len = CycleLength2(CycleHead); //获取环长度
while (cur1 != cur2&&len--)
{
cur2 = cur2->_next;
}
if (cur1 == cur2)
return cur1;
else
cur1 = cur1->_next;
}
if (cur1 == cur2)
return cur1;
return NULL;
}
//判断两个链表是否相交
int IsIntersect(ListNode* pHead1, ListNode* pHead2)
{
ListNode * cur1 = pHead1, *cur2 = pHead2;
ListNode * prevCur1=pHead1,* prevCur2=pHead2;
if (cur1 == NULL)
return 0;
if (cur2 == NULL)
return 0;
while (cur1 != NULL&&cur2 != NULL&&prevCur1!=prevCur2)
{
prevCur1 = cur1;
prevCur2 = cur2;
cur1 = cur1->_next;
cur2 = cur2->_next;
}
if (prevCur1 == prevCur2)
return 1;
else
return 0;
}
2 0
- C++实现单链表(2) 一些函数的实现
- C语言字符串函数的一些实现
- [C/C++]一些常用的随机函数实现
- 3、C函数可变参数实现细节的一些思考
- 一些Linux用到的C工具集常用函数实现
- 强大的格式转换(利用c和c++的一些函数实现)
- 一些共通的函数实现
- 一些共通的函数实现
- 一些通用的函数实现
- 一些共通的函数实现
- 一些字符函数的实现。
- 递归的一些简单实现(c实现)
- 【一些题】一些重要函数的实现
- 折半查找的函数实现(C++)
- 系统函数C字符串的实现(2):strstr
- jpeg_to_yuv函数的C实现
- C常用函数的实现
- c _alloca 函数的实现
- CocoaPods安装和使用教程
- hdu1217 floyd
- WebKit之Page类
- Josephu程序
- WebKit之加载模块
- C++实现单链表(2) 一些函数的实现
- 互联网+脑科学,21世纪带给中国重大理论创新机遇
- POJ1936-All-in-All(子序列)
- WebKit之video解析
- 嵌入式系统之KPN网络图(Kahn Process Networks)
- JAVA字符串占位符替换
- UIAlertView更换为UIAlerController
- iOS_正则表达式
- CSS去掉li中前面的点