数据结构
天才是从醒悟开始的
目标+努力+坚持
展开
-
C 语言指针实现二分法
#include<stdio.h>int *dichotomy(int *a,int num,int flag){ int *low = a; int *heigh = a+num; int *mid = NULL; while(low < heigh){ mid = low + (heigh-low)/2; if((*mid) == flag){ return mid; } else if((*mid) > flag){ heigh = m.原创 2020-11-04 16:11:25 · 497 阅读 · 1 评论 -
leetcode.102 二叉树的层序遍历
给你一个二叉树,请你返回其按 层序遍历 得到的节点值。 (即逐层地,从左到右访问所有节点)。示例:二叉树:[3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍历结果:[ [3], [9,20], [15,7]]思路:利用队列的先进先出的规则,让每一层的节点先进入,然后要出队时,再把他的左右节点加入队列的末尾,以此类推。/** * Definition for a b...转载 2020-11-02 10:49:45 · 153 阅读 · 0 评论 -
leetcode.234 回文链表
请判断一个链表是否为回文链表。示例 1:输入: 1->2输出: false示例 2:输入: 1->2->2->1输出: true进阶:你能否用O(n) 时间复杂度和 O(1) 空间复杂度解决此题?思路一:可以遍历链表将值存入数组中,然后再在数组从前后进行回文判断。/** * Definition for singly-linked list. * struct ListNode { * int val; * st.原创 2020-10-26 20:15:52 · 67 阅读 · 0 评论 -
leetcode 121. 买卖股票的最佳时机
给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格。如果你最多只允许完成一笔交易(即买入和卖出一支股票),设计一个算法来计算你所能获取的最大利润。注意你不能在买入股票前卖出股票。示例 1:输入: [7,1,5,3,6,4]输出: 5解释: 在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。 ...原创 2018-10-03 10:42:28 · 208 阅读 · 0 评论 -
leetcode70. 爬楼梯
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?注意:给定 n 是一个正整数。示例 1:输入: 2输出: 2解释: 有两种方法可以爬到楼顶。1. 1 阶 + 1 阶2. 2 阶示例 2:输入: 3输出: 3解释: 有三种方法可以爬到楼顶。1. 1 阶 + 1 阶 + 1 阶2. ...原创 2018-10-02 11:00:03 · 101 阅读 · 0 评论 -
leetcode.102 二叉树的层次遍历
给定一个二叉树,返回其按层次遍历的节点值。 (即逐层地,从左到右访问所有节点)。例如:给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回其层次遍历结果:[ [3], [9,20], [15,7]]思路:利用队列先进先出的特点,将二叉树的结点存储进队列中,另外使用 ...原创 2018-09-26 10:07:23 · 75 阅读 · 0 评论 -
leetcode278. 第一个错误的版本
你是产品经理,目前正在带领一个团队开发新的产品。不幸的是,你的产品的最新版本没有通过质量检测。由于每个版本都是基于之前的版本开发的,所以错误的版本之后的所有版本都是错的。假设你有 n 个版本 [1, 2, ..., n],你想找出导致之后所有版本出错的第一个错误的版本。你可以通过调用 bool isBadVersion(version) 接口来判断版本号 version 是否在单元测试中出...原创 2018-10-01 11:33:53 · 139 阅读 · 0 评论 -
leetcode21. 合并两个有序链表
将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。示例:输入:1->2->4, 1->3->4输出:1->1->2->3->4->4思路:利用归并排序的思想,循环遍历两个链表,如果遍历到的第一个链表的值小于第二个链表的值,那么将小的链表结点加入新的链表即可,反之如果比第二个链表的结点大...原创 2018-09-15 10:14:15 · 114 阅读 · 0 评论 -
leetcode206. 反转链表
反转一个单链表。示例:输入: 1->2->3->4->5->NULL输出: 5->4->3->2->1->NULL进阶:你可以迭代或递归地反转链表。你能否用两种方法解决这道题?思路:利用两个指针,一个 p 保存原链表,另一个 newH 保存反转后的链表的头结点。遍历原链表,并使用一个临时结点 tmp 保存遍历的每一次...原创 2018-09-14 11:14:39 · 87 阅读 · 0 评论 -
leetcode19. 删除链表的倒数第N个节点
给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。示例:给定一个链表: 1->2->3->4->5, 和 n = 2.当删除了倒数第二个节点后,链表变为 1->2->3->5.说明:给定的 n 保证是有效的。思路:链表的特点是查找困难,因此定位到要删除的结点,就要花会功夫。这里想到的是,利用链表长度 - n ...原创 2018-09-14 10:48:29 · 80 阅读 · 0 评论 -
leetcode101. 对称二叉树
给定一个二叉树,检查它是否是镜像对称的。例如,二叉树 [1,2,2,3,4,4,3] 是对称的。 1 / \ 2 2 / \ / \3 4 4 3但是下面这个 [1,2,2,null,3,null,3] 则不是镜像对称的: 1 / \ 2 2 \ \ 3 3说明:如果你可以运用递归和迭代两种方法解...原创 2018-09-23 16:16:16 · 102 阅读 · 0 评论 -
leetcode141. 环形链表
给定一个链表,判断链表中是否有环。进阶:你能否不使用额外空间解决此题?思路:刚开始想着让他循环下去,直到和头结点相同的时候,就返回 true,否则就返回 false,但还是 too young too naive。实际上还是设置两个指针,一个快指针和一个慢指针,只要是在环里面,总会相遇的,就可 return true 了。/** * Definition for singly...原创 2018-09-18 14:58:25 · 250 阅读 · 0 评论 -
leetcode104. 二叉树的最大深度
给定一个二叉树,找出其最大深度。二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。说明: 叶子节点是指没有子节点的节点。示例:给定二叉树 [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7返回它的最大深度 3 。思路:若一个二叉树为空,则它的深度为 0 ,否则它的深度等于左子树和右子树中的...原创 2018-09-20 20:50:15 · 127 阅读 · 0 评论 -
leetcode 412. Fizz Buzz
写一个程序,输出从 1 到 n 数字的字符串表示。1. 如果 n 是3的倍数,输出“Fizz”;2. 如果 n 是5的倍数,输出“Buzz”;3.如果 n 同时是3和5的倍数,输出 “FizzBuzz”。思路:直接暴力破解了,但要注意细节,我之前是将「Fizz」,「Buzz」,「FizzBuzz」用 a,b,c 保存,然后添加a,b,c进去的,但还是直接往 List 加这些字母快点...原创 2018-09-20 21:25:03 · 192 阅读 · 0 评论 -
数据结构 -- 栈
基本特点:后入先出的结构,就好像子弹夹一样,最先压进的子弹总是最后射出。基本方法实现:动态数组实现,push,pop,isEmptyclass MyStack { private List<Integer> data; // store elements public MyStack() { data = new A...原创 2019-03-23 10:50:07 · 100 阅读 · 0 评论 -
数据结构篇——队列
队列的特点:先入先出,就好像饭堂排队打饭的排的队一样,排第一的先拿到饭去打菜,跑得快,拿第一有饭吃,跑得慢。。。。操作:插入,在队尾插入元素,就好像在饭堂打饭需要按序排队。 删除,删除队首的元素,就好像在饭堂拿到饭的人,不能老是在第一站着位置。实现:class Queue{ List<Integer> list; int ...原创 2019-03-16 00:46:13 · 175 阅读 · 0 评论 -
leetcode.852 山脉数组的峰顶索引
我们把符合下列属性的数组 A 称作山脉:A.length >= 3 存在 0 < i < A.length - 1 使得A[0] < A[1] < ... A[i-1] < A[i] > A[i+1] > ... > A[A.length - 1]给定一个确定为山脉的数组,返回任何满足 A[0] < A[1] < ... A...原创 2018-11-14 11:10:18 · 189 阅读 · 0 评论 -
树的高度和深度的区别
对于树的基本概念上理解,对于才接触数据结构的人来说,树的高度和深度是一个容易混淆的知识点,现解释如下:1.高度对于高度的理解,我们不管他数据结构什么什么知识,就拿楼房来说,假如一个人提问:楼房的高度有好高?我们会下意识的从底层开始往上数,假如楼有6层,则我们会说,这个楼有6层楼那么高,则提问者就会大概知道楼有多高了。所以高度就是以从下往上对比,这是我们的习惯。而在树中,树的高度也是从下往上...转载 2018-10-30 16:55:10 · 478 阅读 · 1 评论 -
leetcode 198. 打家劫舍
你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。给定一个代表每个房屋存放金额的非负整数数组,计算你在不触动警报装置的情况下,能够偷窃到的最高金额。示例 1:输入: [1,2,3,1]输出: 4解释: 偷窃 1 号房屋 (金额 = 1) ,然后偷窃...原创 2018-10-10 11:58:14 · 108 阅读 · 0 评论 -
leetcode 53. 最大子序和
给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。示例:输入: [-2,1,-3,4,-1,2,1,-5,4],输出: 6解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。进阶:如果你已经实现复杂度为 O(n) 的解法,尝试使用更为精妙的分治法求解。思路:循环遍历数组,将每一次相加的位置和结果保存之前比较大小...原创 2018-10-04 19:40:06 · 120 阅读 · 0 评论 -
leetcode.384 打乱数组
打乱一个没有重复元素的数组。示例:// 以数字集合 1, 2 和 3 初始化数组。int[] nums = {1,2,3};Solution solution = new Solution(nums);// 打乱数组 [1,2,3] 并返回结果。任何 [1,2,3]的排列返回的概率应该相同。solution.shuffle();// 重设数组到它的初始状态[1,2,3]。...原创 2018-10-11 21:34:30 · 471 阅读 · 0 评论 -
leetcode 98. 验证二叉搜索树
给定一个二叉树,判断其是否是一个有效的二叉搜索树。假设一个二叉搜索树具有如下特征:节点的左子树只包含小于当前节点的数。 节点的右子树只包含大于当前节点的数。 所有左子树和右子树自身必须也是二叉搜索树。示例1:输入: 2 / \ 1 3输出: true示例2:输入: 5 / \ 1 4 / \ 3 ...原创 2018-09-21 10:55:31 · 239 阅读 · 0 评论 -
leetcode125. 验证回文串
给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。说明:本题中,我们将空字符串定义为有效的回文串。示例 1:输入: "A man, a plan, a canal: Panama"输出: true示例 2:输入: "race a car"输出: false思路:验证回文字符串,使用两个指针,一个指针从头开始自加,一个指针从尾开始自减,...原创 2018-09-07 10:53:39 · 101 阅读 · 0 评论 -
leetcode 237. 删除链表中的节点
请编写一个函数,使其可以删除某个链表中给定的(非末尾)节点,你将只被给定要求被删除的节点。现有一个链表 --head =[4,5,1,9],它可以表示为: 4 -> 5 -> 1 -> 9示例 1:输入: head = [4,5,1,9], node = 5输出: [4,1,9]解释: 给定你链表中值为5的第二个节点,那么在调用了你的函数之...原创 2018-09-12 12:39:52 · 255 阅读 · 0 评论 -
leetcode28. 实现strStr()
实现strStr()函数。给定一个haystack 字符串和一个 needle 字符串,在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如果不存在,则返回-1。示例 1:输入: haystack = "hello", needle = "ll"输出: 2示例 2:输入: haystack = "aaaaa", needl...原创 2018-09-09 11:07:19 · 266 阅读 · 0 评论 -
leetcode 75 颜色分类
给定一个包含红色、白色和蓝色,一共 n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。此题中,我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。注意:不能使用代码库中的排序函数来解决这道题。示例:输入: [2,0,2,1,1,0]输出: [0,0,1,1,2,2]进阶:一个直观的解决方案是使用计数排序的两趟扫描...原创 2018-08-20 15:57:04 · 173 阅读 · 0 评论 -
leetcode 171. Excel表列序号
给定一个Excel表格中的列名称,返回其相应的列序号。例如, A -> 1 B -> 2 C -> 3 ... Z -> 26 AA -> 27 AB -> 28 ...示例 1:输入: "A"输出: 1示例 2:输入: "AB"输出: 28示例 3:...翻译 2018-08-16 15:27:28 · 279 阅读 · 0 评论 -
leetcode 283 移动零
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。示例:输入: [0,1,0,3,12]输出: [1,3,12,0,0]说明:必须在原数组上操作,不能拷贝额外的数组。 尽量减少操作次数。思路:重设另外一个数组,保存题目数组的非零元素,之后再设置第二个数组的没赋值的,赋值为 0 ,最后将第二个弄好的数组赋值给原先的数组,空间复杂度 ...原创 2018-08-18 19:56:16 · 98 阅读 · 0 评论 -
leetcode 66 加一
给定一个非负整数组成的非空数组,在该数的基础上加一,返回一个新的数组。最高位数字存放在数组的首位, 数组中每个元素只存储一个数字。你可以假设除了整数 0 之外,这个整数不会以零开头。示例 1:输入: [1,2,3]输出: [1,2,4]解释: 输入数组表示数字 123。示例 2:输入: [4,3,2,1]输出: [4,3,2,2]解释: 输入数组表示数字 43...原创 2018-08-13 15:51:03 · 96 阅读 · 0 评论 -
leetcode 69 x 的平方根
实现 int sqrt(int x) 函数。计算并返回 x 的平方根,其中 x 是非负整数。由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去。示例 1:输入: 4输出: 2示例 2:输入: 8输出: 2说明: 8 的平方根是 2.82842..., 由于返回类型是整数,小数部分将被舍去。取巧的代码,直接调用 Math 中的 sqrt 方...原创 2018-08-15 15:05:38 · 149 阅读 · 0 评论 -
leetcode 13. 罗马数字转整数
罗马数字包含以下七种字符:I, V, X, L,C,D 和 M。字符 数值I 1V 5X 10L 50C 100D 500M 1000例如, 罗马数字 2 写做 II ,即为两个并列的 1。...原创 2018-08-07 11:40:44 · 92 阅读 · 0 评论 -
67 leetcode 二进制求和
给定两个二进制字符串,返回他们的和(用二进制表示)。输入为非空字符串且只包含数字 1 和 0。示例 1:输入: a = "11", b = "1"输出: "100"示例 2:输入: a = "1010", b = "1011"输出: "10101"思路:重设一位标志 carryBit 记录是否进位,进位的话加上高一位加上carryBit 这位,但是这样的话要原创 2018-08-14 16:07:09 · 144 阅读 · 0 评论 -
leetcode 9 回文数
判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。示例 1:输入: 121输出: true示例 2:输入: -121输出: false解释: 从左向右读, 为 -121 。 从右向左读, 为 121- 。因此它不是一个回文数。示例 3:输入: 10输出: false解释: 从右向左读, 为 01 。因此它不是一个回文...原创 2018-08-06 11:04:37 · 107 阅读 · 0 评论 -
编写一个静态方法 lg(),接受一个整型参数,返回不大于以 2 为底的 log 的最大整数。
首先考虑两种情况,分别是大于 1 和小于 1 并且大于 0 的。大于 1 和小于 0 的,从 1 开始自除,并用一个数记录下除了多少次,但是这种情况下的数是负数,所以要 -1。第二种情况是,大于 1 的,从 1 开始乘以 2 逼近目标数,并用一个数标记乘了多少次,最后记得减 1 ,因为最后逼近了数之后,还加 1 了。 第三种情况,都不是上面两种情况的,返回 -1。static int lg(dou...原创 2018-07-16 09:52:43 · 233 阅读 · 0 评论 -
leetcode 189 旋转数组
给定一个数组,将数组中的元素向右移动 k 个位置,其中 k 是非负数。示例 1:输入: [1,2,3,4,5,6,7] 和 k = 3输出: [5,6,7,1,2,3,4]解释:向右旋转 1 步: [7,1,2,3,4,5,6]向右旋转 2 步: [6,7,1,2,3,4,5]向右旋转 3 步: [5,6,7,1,2,3,4]示例 2:输入: [-1,-100,3,...原创 2018-08-26 15:44:23 · 144 阅读 · 0 评论 -
leetcode 88 合并两个有序数组
给定两个有序整数数组 nums1 和 nums2,将 nums2 合并到 nums1 中,使得 num1 成为一个有序数组。说明:初始化 nums1 和 nums2 的元素数量分别为 m 和 n。 你可以假设 nums1 有足够的空间(空间大小大于或等于 m + n)来保存 nums2 中的元素。示例:输入:nums1 = [1,2,3,0,0,0], m = 3nums2 ...原创 2018-08-20 18:50:46 · 160 阅读 · 0 评论 -
leetcode 136 只出现一次的数字
给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。说明:你的算法应该具有线性时间复杂度。 你可以不使用额外空间来实现吗?示例 1:输入: [2,2,1]输出: 1示例 2:输入: [4,1,2,1,2]输出: 4思路:首先要不同的数就是异或运算^了:在计算机内的换成二进制计算,相同为 0 ,不同为 1 ,根据...原创 2018-08-31 18:35:49 · 94 阅读 · 0 评论 -
leetcode 36. 有效的数独
判断一个 9x9 的数独是否有效。只需要根据以下规则,验证已经填入的数字是否有效即可。数字 1-9 在每一行只能出现一次。 数字 1-9 在每一列只能出现一次。 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。上图是一个部分填充的有效的数独。数独部分空格内已填入了数字,空白格用 '.' 表示。示例 1:输入:[ ["5","3",".",".","...原创 2018-09-03 10:35:28 · 457 阅读 · 0 评论 -
leetcode 48 旋转图像
给定一个 n × n 的二维矩阵表示一个图像。将图像顺时针旋转 90 度。说明:你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要使用另一个矩阵来旋转图像。示例 1:给定 matrix = [ [1,2,3], [4,5,6], [7,8,9]],原地旋转输入矩阵,使其变为:[ [7,4,1], [8,5,2], [9,6,3...原创 2018-09-03 10:28:08 · 149 阅读 · 0 评论 -
leetcode14. 最长公共前缀
编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀,返回空字符串 ""。示例 1:输入: ["flower","flow","flight"]输出: "fl"示例 2:输入: ["dog","racecar","car"]输出: ""解释: 输入不存在公共前缀。说明:所有输入转载 2018-09-11 16:21:09 · 80 阅读 · 0 评论