Sakuta Azusagawa
Sakuta Azusagawa
全部文章
剑指Offer
Golang(8)
Java(22)
Leetcode题解(108)
Redis(1)
操作系统(2)
计算机组成原理(1)
计算机网络(3)
设计模式(17)
归档
标签
去牛客网
登录
/
注册
youzhihua的博客
有志者,事竟成,破釜沉舟,百二秦关终属楚;苦心人,天不负,卧薪尝胆,三千越甲可吞吴
全部文章
/ 剑指Offer
(共56篇)
二叉树的深度
题目描述 输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。 示例 给定二叉树 [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7 返回它的最大深度 ...
Golang
算法
Java
剑指Offer
2020-02-29
0
475
数字在排序数组中出现的次数
题目描述 统计一个数字在排序数组中出现的次数。 示例: 输入: nums = [5,7,7,8,8,10], target = 8 输出: 2思路 1.排序数组中,相同的数字时连在一起的。2.进行两次二分查找,分别查找目标数字的左边界索引和右边界索引,最后进行区间计算即可。注:可以在第一次二分查找后...
Golang
算法
Java
剑指Offer
2020-02-28
0
492
两个链表的第一个公共结点
题目描述 输入两个链表,找出它们的第一个公共结点。(注意因为传入数据是链表,所以错误测试数据的提示是用其他方式显示的,保证传入数据是正确的) 思路 假设两个链表的第一个公共结点为c。 链表1可以表示为a+c,链表2可以表示为b+c。 可以通过a+c+b+c = b+c+a+c来快速求出c的值,若没...
Golang
算法
Java
剑指Offer
2020-02-27
0
558
数组中的逆序对
题目描述 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P%1000000007 输入描述 题目保证输入的数组中没有的相同的数字 数据范围: 对于%50的数...
Golang
算法
Java
剑指Offer
2020-02-27
0
512
第一个只出现一次的字符
题目描述 在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写). 思路 先将字符串遍历一次,使用map存储每个字符出现的次数。 再将字符串遍历一次,若当前字符在map中对应的次数是1,即为正...
Golang
算法
Java
剑指Offer
2020-01-19
0
493
丑数
题目描述 把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。 思路 1.首先写出几个连续的丑数。2.我们可以很容易的推导出状态转移方程为:dp[i] = min(2dp...
Golang
算法
Java
剑指Offer
2020-01-17
0
461
把数组排成最小的数
题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。 思路 此问题其实属于排序问题。 需要比较num1+num2的组合与num2+num1的组合,将小的放在前面。...
Golang
算法
Java
剑指Offer
2020-01-17
0
538
连续子数组的最大和
题目描述 HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1...
Golang
算法
Java
剑指Offer
2020-01-15
0
540
最小的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
首页
上一页
1
2
3
4
5
6
下一页
末页