题目要求:

  输入一个链表,输出该链表中倒数第k个结点。链表的倒数第0个结点为链表的尾指针。

  参考资料:剑指offer第15题

题目分析:

  1.两个指针,第一个先走k步,然后两个指针同时走,直到第一个走到尾指针,此时第二个指针即为所求;

  2.令函数原型为:ListNode *findKthToTail(ListNode *head,unsigned int k);

   特殊情况:

      i). head为空指针;

      ii). head为头结点的链表的结点总数小于k;

      iii).k=0.

  3.注意此处为倒数第0个结点为链表的尾结点,与剑指offer的第一个结点的区别是:第0个结点的最后一个while里应该ptwo->next != NULL;而第1个结点的最后一个while里应该ptwo != NULL。可画图理解。

代码实现: 

#include <iostream>

using namespace std;

typedef struct ListNode
{
struct ListNode *next;
int data;
}ListNode;
ListNode *findKthToTail(ListNode *head,unsigned int k);
void initList(ListNode **head); int main(void)
{
// int k = 4;
int k = ;
ListNode *head; initList(&head);
head = findKthToTail(head,k); if(head==NULL)
cout << "head为空或者链表长度小于k";
else
cout << head->data << " ";
cout << endl; return ;
}
ListNode *findKthToTail(ListNode *head,unsigned int k)
{
if(k== || head==NULL)
return NULL; ListNode *pone,*ptwo;
pone = ptwo = head;
for( ; k > && ptwo != NULL; k--)
ptwo=ptwo->next;
if (k > ) return NULL;//链表长度小于k
while(ptwo->next != NULL)
{
pone=pone->next;
ptwo=ptwo->next;
}
return pone;
}
//1-->2-->3-->NULL
void initList(ListNode **head)
{
ListNode *tmp = new ListNode;
tmp->data = ;
*head = tmp; tmp = new ListNode;
tmp->data = ;
(*head)->next = tmp; ListNode *tmp1 = new ListNode;
tmp1->data = ;
tmp1->next = NULL;
tmp->next = tmp1;
}

最新文章

  1. Linux系统下Nginx安装详解
  2. css做三角形
  3. linux 查找php.ini 文件
  4. [ruby on rails] 跟我学之(2)HelloWorld
  5. 关于prototype
  6. OpenTSDB介绍——基于Hbase的分布式的,可伸缩的时间序列数据库,而Hbase本质是列存储
  7. CODEVS1533 互斥的数(哈希表)
  8. (转)高性能I/O模型
  9. [Java] JavaMail 查询邮件
  10. mysql命令行执行外部文件
  11. mrtg监控网络流量简单配置
  12. Android模拟器的文件目录介绍
  13. CountDownLatch, CyclicBarrier and Semaphore
  14. jumpserver V0.4.0 在CentOs7上的安装
  15. 201421123042 《Java程序设计》第6周学习总结
  16. vc++基础班[21]---文件的基本操作之CFile
  17. Webpack 2 视频教程 007 - 配置 WDS 进行浏览器自动刷新
  18. 质控工具之cutadapt的使用方法
  19. js记录用户访问页面和停留时间
  20. Android——简单对话框实现

热门文章

  1. JavaScript笔记3--标识符和保留字
  2. Unity的stateMachineBehaviour
  3. npm使用快速的安装源(nrm)
  4. LR使用流程简介之录制方式说明
  5. 前端APP打包管理规范
  6. UVA 1609 Foul Play 不公平竞赛 (构(luan)造(gao)+递归)
  7. Hybrid App开发之Html基本标签使用
  8. ubuntu下安装eclipse&lt;转&gt;
  9. MFC:Unicode和多字节字符集下 CString和char的转化(MFC中)
  10. Java获取yml里面的配置