haovcf 发表于 2015-1-2 12:44:09

单链循环表逆置操作 ,无法打印,问题在哪里

/*
   做一个单链循环链表逆置的操作,函数做出来,达不到预期的目的,百思不得其解。
   只要把单链表逆置 然后 ,输入就可以了。
   谁来看看。。
*/
// pcnodelist 的数据结构 是一个单链循环表
typedef struct cnodelist{
    elemtype data ;
    struct cnodelist *next ;
}*pcnodelist ;

// 这个函数有问题
// p 表示循环单链表的当前循环点,pre 是 p 节点的前面一节点 , pnext 是pnext 的后面一节点
//函数思想,先用pnext 保存p->next , 然后把p->next 更新成前一节点的值 , 然后更新p , 和pre 的值 ,一直循环到当前节点是head 头节点时
void reversecnodelist( pcnodelist head )
{
    pcnodelist pre = head , p = head->next , pnext = NULL ;
    while( p!= head )
    {
      pnext = p->next ;
      p->next = pre ;
      pre = p ;
      p = pnext ;
    }
    head->next = p ;
    printf("try to test it ,may be reverse it !\n") ;
   
}

haovcf 发表于 2015-1-2 18:21:23

最后我用更新的版本试了下,输出了正确结果。。
这难道是编译器的问题。。我晕了。。
页: [1]
查看完整版本: 单链循环表逆置操作 ,无法打印,问题在哪里