鱼C论坛

 找回密码
 立即注册
查看: 1925|回复: 0

请教各位大虾,为什么我的链表会陷入死循环呢?

[复制链接]
发表于 2014-11-3 01:08:36 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
代码如下:
  1. #include <iostream>
  2. using namespace std;
  3. template <class T>
  4. class Chain;
  5. template <class T>
  6. class ChainNode
  7. {
  8.         friend class Chain<T>;
  9.         friend ostream& operator<< <T>(ostream& out, const Chain<T>& x);
  10. private:
  11.         T data;
  12.         ChainNode<T>* link = 0;
  13. };


  14. //重载 <<
  15. template<class T>
  16. ostream& operator<< (ostream& out, const Chain<T>& x)
  17. {
  18.         ChainNode<T>* p;
  19.         for (p = x.first; p; p = p->link)
  20.         {
  21.                 out << p->data << "->";
  22.         }
  23.         return out;
  24. }


  25. template <class T>
  26. class Chain
  27. {
  28.         friend ostream& operator<< <T>(ostream& out, const Chain<T>& x);
  29. public:
  30.         Chain(){ first = 0; }
  31.         Chain<T>& InsertChange(int k);
  32.         void split(Chain& A, Chain& B);
  33. private:
  34.         ChainNode<T>* first;//指向第一个节点的指针
  35. };



  36. int main()
  37. {
  38.         Chain<int> test;
  39.         for (int i = 0; i < 10; i++)
  40.         {
  41.                 test.InsertChange(i);
  42.         }
  43.         cout << test << endl;
  44.         Chain<int> A, B;
  45.         test.split(A, B);
  46.         cout << A << endl;
  47.         cout << B << endl;
  48.         return 0;

  49. }

  50. template <class T>
  51. Chain<T>& Chain<T>::InsertChange(int k)
  52. {
  53.         ChainNode<T>* p = new ChainNode<T>;
  54.         ChainNode<T>* q;
  55.         p->data = k;
  56.         if (!first)
  57.         {
  58.                 first = p;
  59.         }
  60.         else
  61.         {
  62.                 q = first;
  63.                 while (q->link)
  64.                 {
  65.                         q = q->link;
  66.                 }
  67.                 q->link = p;
  68.         }
  69.         return *this;
  70. }

  71. template<class T>
  72. void Chain<T>::split(Chain& A, Chain& B)
  73. {
  74.         ChainNode<T>* p = first;
  75.         ChainNode<T>* q = 0;
  76.         ChainNode<T>* r = 0;
  77.         int i = 0;
  78.         while (p)
  79.         {
  80.                 if (first == NULL)
  81.                 {
  82.                         return;
  83.                 }
  84.                 i++;
  85.                 if (i % 2 != 0)
  86.                 {
  87.                         q = p;
  88.                         q->link = q;
  89.                 }
  90.                 else
  91.                 {
  92.                         r = p;
  93.                         r->link = r;
  94.                 }
  95.                 p = p->link;
  96.         }
  97.         A.first = q;
  98.         B.first = r;
  99.         return;

  100. }
复制代码

只是在拆分这个函数出现死循环
  1. template<class T>
  2. void Chain<T>::split(Chain& A, Chain& B)
  3. {
  4.         ChainNode<T>* p = first;
  5.         ChainNode<T>* q = 0;
  6.         ChainNode<T>* r = 0;
  7.         int i = 0;
  8.         while (p)
  9.         {
  10.                 if (first == NULL)
  11.                 {
  12.                         return;
  13.                 }
  14.                 i++;
  15.                 if (i % 2 != 0)
  16.                 {
  17.                         q = p;
  18.                         q->link = q;
  19.                 }
  20.                 else
  21.                 {
  22.                         r = p;
  23.                         r->link = r;
  24.                 }
  25.                 p = p->link;
  26.         }
  27.         A.first = q;
  28.         B.first = r;
  29.         return;

  30. }
复制代码

还请多多指教!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-17 23:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表