摘要: 题目描述: 输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针random指向一个随机节点),请对此链表进行深拷贝,并返回拷贝后的头结点。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空) 阅读全文
posted @ 2020-09-05 21:41 手下留情 阅读(126) 评论(0) 推荐(0) 编辑
摘要: 1、数据存放位置不同: cookie数据存放在客户的浏览bai器上,session数据放在服务器上。 2、安全程度不同: cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKIE欺骗,考虑到安全应当使用session。 3、性能使用程度不同: session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能,考虑到减轻服务器性能方面,应当使用cookie。 4、数据存储大小不同: 单个cookie保存的数据不能超过4K,很多浏览器都限制一个站点最多保存20个cookie,而session则存储与服务端,浏览器对其没有限制。 阅读全文
posted @ 2020-09-04 14:45 手下留情 阅读(1084) 评论(0) 推荐(0) 编辑
摘要: 题目描述: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。 解题思路: 我们可以用迭代的方法来实现上述算法。当 l1 和 l2 都不是空链表时,判断 l1 和 l2 哪一个链表的头节点的值更小,将较小值的节点添加到结果里,当一个节点被添加到结果里之后,将对应链表中的节点向后移一位。 首先,我们设定一个哨兵节点 prehead ,这可以在最后让我们比较容易地返回合并后的链表。我们维护一个 prev 指针,我们需要做的是调整它的 next 指针。然后,我们重复以下过程,直到 l1 或者 l2 指向了 null :如果 l1 当前节点的值小于等于 l2 ,我们就把 l1 当前的节点接在 prev 节点的后面同时将 l1 指针往后移一位。 阅读全文
posted @ 2020-08-21 10:18 手下留情 阅读(84) 评论(0) 推荐(0) 编辑
摘要: 题目描述: 输入一个链表,反转链表后,输出新链表的表头。 解题思路: 比较简单,直接上代码 阅读全文
posted @ 2020-08-21 09:41 手下留情 阅读(234) 评论(0) 推荐(0) 编辑
摘要: 题目描述: 输入一个链表,输出该链表中倒数第k个结点。 解题思路: 设链表的长度为 N。设置两个指针 P1 和 P2,先让 P1 移动 K 个节点,则还有 N - K 个节点可以移动。此时让 P1 和 P2 同时移动,可以知道当 P1 移动到链表结尾时,P2 移动到第 N - K 个节点处,该位置就是倒数第 K 个节点。 阅读全文
posted @ 2020-08-20 15:48 手下留情 阅读(67) 评论(0) 推荐(0) 编辑
摘要: 题目描述: 输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有的奇数位于数组的前半部分,所有的偶数位于数组的后半部分,并保证奇数和奇数,偶数和偶数之间的相对位置不变。 解题思路: 用两个下标odd,even,even遍历数组,遇到偶数继续往后走,遇到奇数就将该奇数赋给odd对应位置,然后odd往后移动(先将从odd开始的位置的所有元素往后挪动一个,这样做的目的是能够保持偶数相对位置不变)。这个思路也就是使得odd前面的都是奇数,而且相对位置不变,而odd与even之间的都是偶数,然后even遇到奇数停下来,并将其放到odd位置,并且前提是将odd位置上的偶数向后挪动保证偶数相对位置不变,这样当even走到最后时,就使得odd之前的都是奇数,odd与even之间的都是偶数。 阅读全文
posted @ 2020-08-20 15:34 手下留情 阅读(157) 评论(0) 推荐(0) 编辑
摘要: 题目描述: 地上有一个m行和n列的方格。一个机器人从坐标0,0的格子开始移动,每一次只能向左,右,上,下四个方向移动一格,但是不能进入行坐标和列坐标的数位之和大于k的格子。 例如,当k为18时,机器人能够进入方格(35,37),因为3+5+3+7 = 18。但是,它不能进入方格(35,38),因为3+5+3+8 = 19。请问该机器人能够达到多少个格子? 解题思路: 利用递归实现,每次只能走上下左右四个点,进行判断点的位置是否越界,点数之和是否大于K,是否已经走过了。 阅读全文
posted @ 2020-08-14 16:13 手下留情 阅读(122) 评论(0) 推荐(0) 编辑
摘要: 题目描述: 一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。 解题思路: 要想跳到第n级台阶,就可以从第n-1级、第n-2级、***、第1级 跳到第n级,再加上直接从地面到第n级的一种情况。 将问题分解为求子问题递归。 阅读全文
posted @ 2020-08-12 11:40 手下留情 阅读(99) 评论(0) 推荐(0) 编辑
摘要: 题目描述: 一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。 解题思路: 这是一道经典的递推题目,你可以想如果青蛙当前在第n级台阶上,那它上一步是在哪里呢? 显然,由于它可以跳1级台阶或者2级台阶,所以它上一步必定在第n-1,或者第n-2级台阶,也就是说它跳上n级台阶的跳法数是跳上n-1和跳上n-2级台阶的跳法数之和。 设跳上 级台阶有 种跳法,则它跳上n级的台阶有 种跳法。 然后,我们又思考初始()的情况,跳上1级台阶只有1种跳法,跳上2级台阶有2种跳法,最终我们得到如下的递推式: 阅读全文
posted @ 2020-08-12 11:18 手下留情 阅读(79) 评论(0) 推荐(0) 编辑
摘要: 题目描述: 求斐波那契数列的第 n 项,n <= 39。 解题思路: 如果使用递归求解,会重复计算一些子问题。例如,计算 f(4) 需要计算 f(3) 和 f(2),计算 f(3) 需要计算 f(2) 和 f(1),可以看到 f(2) 被重复计算了。 阅读全文
posted @ 2020-08-12 09:52 手下留情 阅读(78) 评论(0) 推荐(0) 编辑