链表中倒数第k个结点 【微软面试100题 第十三题】
2024-10-20 13:44:42
题目要求:
输入一个链表,输出该链表中倒数第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;
}
最新文章
- Linux系统下Nginx安装详解
- css做三角形
- linux 查找php.ini 文件
- [ruby on rails] 跟我学之(2)HelloWorld
- 关于prototype
- OpenTSDB介绍——基于Hbase的分布式的,可伸缩的时间序列数据库,而Hbase本质是列存储
- CODEVS1533 互斥的数(哈希表)
- (转)高性能I/O模型
- [Java] JavaMail 查询邮件
- mysql命令行执行外部文件
- mrtg监控网络流量简单配置
- Android模拟器的文件目录介绍
- CountDownLatch, CyclicBarrier and Semaphore
- jumpserver V0.4.0 在CentOs7上的安装
- 201421123042 《Java程序设计》第6周学习总结
- vc++基础班[21]---文件的基本操作之CFile
- Webpack 2 视频教程 007 - 配置 WDS 进行浏览器自动刷新
- 质控工具之cutadapt的使用方法
- js记录用户访问页面和停留时间
- Android——简单对话框实现