面试题:链表

链表反转


注意三个问题:

1. 需要注意头节点的处理;
2. 需要注意尾节点的处理;
3. 需要链表不要断开。

void reverse(ListNode * head)
{
     ListNode * newHead = NULL;
     ListNode * node = head;
     ListNode * preNode = NULL;
     while( node != null)
     {
          ListNode * nextNode = node ->next;
          if(nextNode == NULL)
          {
               newHead = node;
          }
          node ->next = preNode;
          preNode = node;
          node = nextNode;
     }
     return newHead;
}

两个链表的第一个公共节点


方法:
1.先计算出两个链表的长度num1、num2和它们的长度之差minus;
2.长的链表先走minus步;
3.两个链表同时向前走,第一个相等的节点即为两个链表的第一个公共节点。

ListNode * FindCommonNode(ListNode * head1, ListNode *head2)
{
     if(head1 == NULL || head2 == NULL)
     {
          return NULL; 
     }

     int len1 = ListLength(head1);
     int len2 = ListLength(head2);

     int max_list = len1;
     int min_list = len2;
     int minus_num = len1 - len2;
     ListNode * max_node = head1;
     ListNode * min_node = head2;

     if(len1 < len2)
     {
          minus_num = len2 - len1;
          max_list = len2;
          min_list = len1; 
          max_node = head2;
          min_node = head1;
     }

     while(minus > 0)
     {
          max_node = max_node->next;
          minus--;
     }
     while(max_node != NULL && min_node != NULL)
     {
          if(max_node == min_node)
          {
               return max_node;
          }
          else
          {
               max_node++;
               min_node++;
          }
     }
     return NULL;
}
int ListLength(ListNode * head)
{
     int len = 0;
     ListNode * node = head;
     while(node != NULL)
     {
          len++;
          node = node->next;
     }
     return len;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值