Sakuta Azusagawa
Sakuta Azusagawa
全部文章
分类
Golang(8)
Java(22)
Leetcode题解(108)
Redis(1)
剑指Offer(56)
操作系统(2)
计算机组成原理(1)
计算机网络(3)
设计模式(17)
归档
标签
去牛客网
登录
/
注册
youzhihua的博客
有志者,事竟成,破釜沉舟,百二秦关终属楚;苦心人,天不负,卧薪尝胆,三千越甲可吞吴
全部文章
(共175篇)
最小的K个数
题目描述 输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。 思路 此问题属于TopK问题,题目中要求取最小的数,所以是建立大根堆。 2.可以借助java原生的优先级队列,底层就是按照建堆思想实现的。 Java代码实现 im...
算法
Java
剑指Offer
2020-01-15
0
519
数组中出现次数超过一半的数字
题目描述 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。 思路 首先对数组进行排序。 2.若存在答案,必定为数组中间的元素。 3.将...
Golang
算法
Java
剑指Offer
2020-01-15
0
515
字符串的排列
题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。 思路 1.这道题可以使用回溯算法求解。2.首先可以模拟人在写全排列的时候,是将排列中的一个字母取出来作为第一个数字...
Golang
Java
算法
剑指Offer
2020-01-15
0
507
二叉搜索树与双向链表
题目描述 输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。 思路 使用递归算法求解。 2.使用两个TreeNode分别存储前一个结点(pre)以及头结点(head)。 3.每个递归方法中,将当前node结点与pre结点进行相连。 ...
算法
Java
剑指Offer
2020-01-15
0
450
复杂链表的复制
题目描述 输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空) 思路 对要拷贝的链表进行两次遍历。 2.第一次遍历以原链表节点为key...
Golang
算法
Java
剑指Offer
2020-01-14
0
520
二叉树中和为某一值的路径
题目描述 输入一颗二叉树的跟节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。(注意: 在返回值的list中,数组长度大的数组靠前) 思路 1.可以使用回溯算法求解。2.穷举遍历树的每个结点,如果当前target==0并...
Golang
算法
Java
剑指Offer
2020-01-14
0
543
二叉搜索树的后序遍历序列
题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则输出Yes,否则输出No。假设输入的数组的任意两个数字都互不相同。 思路 二叉搜索树满足根节点的值大于左孩子并且小于右孩子。 二叉树的后序遍历顺序是:左->右->根,所以序列的最后一位是根节点的值。 递归...
Golang
算法
Java
剑指Offer
2020-01-13
0
400
从上往下打印二叉树
题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印。 思路 借助一个ArrayList充当队列的角色。 每次从队列头部取出元素后,分别判断其左右孩子,若不为空就加入到队尾,若为空则跳过。 当队列中没有元素时,整个二叉树就遍历完成了。 Java代码实现 public class Sol...
Golang
算法
Java
剑指Offer
2020-01-13
0
484
栈的压入、弹出序列
题目描述 输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长...
Golang
Java
算法
剑指Offer
2020-01-13
0
448
包含min函数的栈
题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。 思路 内部使用两个栈解题,一个栈用于正常的栈操作,另一个栈用于min相关操作。 当要push一个元素时,首先与min的栈顶元素比较,若小于,则将其压入min栈中,若大于,则min栈重复...
Java
算法
剑指Offer
2020-01-13
0
553
首页
上一页
1
2
3
4
5
6
7
8
9
10
下一页
末页