单链表转置问题

发布于 2022-09-18 10:20:33 字数 1568 浏览 15 评论 0

原题:
已知一个单链表,要求不增加辅助变量,实现单链表转置,
也就是表尾变表头,表头变表尾。

大家对单链表转置问题,怎么处理的?
我只想出非递归算法,在VC下调试通过。

typedef int Data;

typedef struct Node
{
        Data d;
        Node *next;
}Node;

/********************************************************************
*Name:  
* Node * revert_printf2(Node *h, Node *n);
*Node *h, h is the pointer of previous node
*Node *n, n is the pointer of next node pointed by h->next
*Description:  
*   
*Returns:  
* The pointer of the head node after transpose
********************************************************************/
Node * revert_printf2(Node *h, Node *n)
{
        Node *k, *p, *header;

        h->next = NULL;

        while (NULL !=h && NULL != n)
        {
                k = n->next;
                n->next = h;
                h = n;
                n = k;
        }

        return h;
}

调用的时候,假设head指向头结点

ret = revert_printf2(head, head->next);

ret就是转置后的头结点

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

迷路的信 2022-09-25 10:20:33

递归做法
type struct Node{
...................
} *node;

node reverse(node frist)
  {
      node head, p;

      if(!first || !first->next)  
         return first;

      p = first->next;
      head = reverse(p)
      p->next = first;
      first->next = NULL;

      return head;
  }

谈下烟灰 2022-09-25 10:20:33

小弟,最开始没看清题意写了个递归 ,可惜是2个参数的,

Node *reverse(Node *first, Node *bf)
{
   Node *p, *q;

   if(fist == NULL)
   {
      return fist;
   }

   if(fist->next == NULL)
   {
      fist ->next = bf;
      return first;
   }

   p = first->next;
   q = rerverse(first, first->next);
   first->next = bf;
  
   return q;
}

[ 本帖最后由 lasting007 于 2009-12-4 02:05 编辑 ]

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文