摘要: 题目:输入一个单向链表,输出该链表中倒数第 k 个结点。方案一:先遍历一遍,获取到链表的长度n,然后从头再走n-k步。分析:相当于遍历两遍,第一遍是为了获得链表的长度,而第二遍是找到倒数第k个节点。方案二:一个盲人怎么才能知道他到墙的距离是d?他可以拿一个长度为d的杆子,当杆子碰到墙了,此时他到墙的距离就是d了。基于上面的思想:1.指定一个新的指针p,走k步。如果k步之内就到了null,显然无倒数第k这说法,返回错误即可。2.新指针p到位后,在初始节点再设定一个新的指针root,然后两个指针一起走。当p为null时,输出root所指的节点即可。 阅读全文
posted @ 2013-10-29 18:24 欧麦高德 阅读(301) 评论(0) 推荐(0) 编辑
摘要: 题目:输入一棵二叉树的根结点,求该树的高度。注释:从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的高度。分析:当前节点的高度等于子数高度较大的值+1,递归实现。代码:int BTreeHight(根节点) { if (是叶子节点) return 1; 左子树高度 = BTreeHight(root->left); 右子树高度 = BTreeHight(root->right); int height; if (左子树高度>右子树高度) height = 左子树高度+1; else height = 右子树高度+1; retur... 阅读全文
posted @ 2013-10-29 18:22 欧麦高德 阅读(988) 评论(1) 推荐(0) 编辑