![](https://img-blog.csdnimg.cn/20201014180756919.png?x-oss-process=image/resize,m_fixed,h_64,w_64)
算法练习
JJmaker
一点点地成长
展开
-
leetcode: 102. Binary Tree Level Order Traversal
题目分词:很明显是层次遍历,与图里的 BFS 很像,只是不用设置 visited 标志变量。只是稍微有点难度的是要分别输出每一层的变量,我最初的想法使用队列存储所有节点,是对每一层的节点都计数,只是这样子代码写起来稍微有点麻烦,后来才知道可以在while 循环中再加一层 for 循环解决,while 循环判断队列是否为空,该层 for 循环输出该层的所有节点。代码如下:基于计数:vect...原创 2019-11-02 16:21:45 · 177 阅读 · 0 评论 -
leetcode: 235. Lowest Common Ancestor of a Binary Search Tree
题目:Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in the BST.According to the definition of LCA on Wikipedia: “The lowest common ancestor is defined betw...原创 2019-10-25 15:21:45 · 138 阅读 · 0 评论 -
leetcode: 98. Validate Binary Search Tree
题目:Given a binary tree, determine if it is a valid binary search tree (BST).Assume a BST is defined as follows:The left subtree of a node contains only nodes with keys less than the node's key.T...原创 2019-10-22 19:50:40 · 111 阅读 · 0 评论 -
leetcode:15. 3Sum
题目:Given an array nums of n integers, are there elements a, b, c in nums such that a + b + c = 0? Find all unique triplets in the array which gives the sum of zero.Note:The solution set must not ...原创 2019-10-16 16:25:08 · 80 阅读 · 0 评论 -
leetcode: 242. Valid Anagram
题目:Given two strings s and t , write a function to determine if t is an anagram of s.Example 1:Input: s = "anagram", t = "nagaram"Output: trueExample 2:Input: s = "rat", t = "car"Output: fal...原创 2019-10-13 15:54:50 · 82 阅读 · 0 评论 -
剑指 offer:顺时针打印矩阵
题目描述输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10.分析这题没有想到什么好方法,只能按照题目意思循环打印了。那么关键就是要准确把握四个角点的的位置,我设置了 4 个变量...原创 2019-03-10 18:43:42 · 64 阅读 · 0 评论 -
剑指 offer:从上往下打印二叉树、第一个只出现一次的字符
题目描述从上往下打印出二叉树的每个节点,同层节点从左至右打印。分析此题直接反应就是用队列,没什么好说的,注意下空数组的返回就行了。vector<int> PrintFromTopToBottom(TreeNode* root) { queue<TreeNode *> Q; vector<int> out; if (root == NULL) {...原创 2019-04-10 14:58:30 · 79 阅读 · 0 评论 -
字符串匹配,kmp算法
前几天面试的时候,被问了一个字符串匹配的问题,没写出来,痛定思痛,决定好好地恶补一番。问题:两个字符串 A 和 B,A 的长度大于 B 的长度,问:A 中是否含有 B,若有,有几个。暴力匹配太 low 了,我不想写,kmp 又写不出来,所以当时就直接放弃了。都快被自己菜哭了。言归正传,先求 next 数组。next 数组是用来干嘛的?为了方便,next 数组的下标设置从 1 开始。nex...原创 2019-03-17 16:42:08 · 98 阅读 · 0 评论 -
剑指 offer:包含 min函数的栈
题目描述定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。分析:要找最小值,且时间 O(1), 那么必然要在 push 和 pop 上做文章,否则就得遍历栈了,时间为 O(n)。第一想法是每次在 push 的时候比较当前值与最小值,用一个变量存储,但这样在 pop 时,若 pop的值为最小值,那么新的最小值无法在第一时间找到。然后想到得用数组...原创 2019-03-12 20:48:54 · 75 阅读 · 0 评论 -
二叉树的镜像
题目描述操作给定的二叉树,将其变换为源二叉树的镜像。分析:这题的代码很简单,关键是能不能想到思路。递归对左右子树进行对换即可。代码如下:void Mirror(TreeNode *pRoot) { TreeNode * tmp; if (pRoot == NULL) { return; } tmp = pRoot-&gt;left; pRoot-&gt;left = pRoo...原创 2019-03-09 22:14:39 · 65 阅读 · 0 评论 -
剑指 offer:旋转数组的最小数字
题目描述把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。 输入一个非减排序的数组的一个旋转,输出旋转数组的最小元素。 例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。 NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。分析:此题看似简单,实则坑略大。虽然说了是旋转数组,但也有可能是不旋转的情况,我就是没有考虑到这一点,怎么做都不...原创 2019-03-03 23:10:58 · 69 阅读 · 0 评论 -
剑指 offer:矩形覆盖
题目描述我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?分析:设 f(n) 为 2*n 的矩形的覆盖方法总数。从第一步开始考虑,有两种放法:若竖放,则剩余的矩形为 2*(n-1),放法有 f(n-1) 种;若横放,则其下面也只能横放,剩余的矩形为 2*(n-2),放法有 f(n-2) 种;将所有可能的情况...原创 2019-03-05 21:31:51 · 79 阅读 · 0 评论 -
剑指 Offer:重建二叉树
题目描述输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。分析:前序遍历的第一个字符就是根,在中序数组中找到该根的位置 pos, 则可将中序数组分为两个子数组,分别对应左子树和右子树,同时由于在前序和中序数组中...原创 2019-02-26 16:10:09 · 101 阅读 · 0 评论 -
剑指 offer:变态跳台阶
题目描述一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。分析:设 f(n) 为 n 阶台阶可能的跳法总数若第一次跳一级,剩下 n - 1 个台阶,跳法有 f(n-1) 种;若跳二级,则剩下 n - 2 个台阶,跳法有 f(n-2) 种;。。。。最后:f(n) = f(n-1) +f(n-2) + … + 1代码如下:...原创 2019-03-04 22:05:03 · 90 阅读 · 0 评论 -
剑指 Offer:从尾到头打印链表
题目描述输入一个链表,按链表值从尾到头的顺序返回一个ArrayList。分析:该题比较简单。直接遍历链表,加入 vector 中,然后使用 reverse 函数即可。后来发现有更简单的做法,即使用 insert(),不过懒得改了。代码如下:class Solution {public: vector<int> printListFromTailToHead(ListNo...原创 2019-02-25 15:27:46 · 92 阅读 · 0 评论 -
剑指 offer:栈的压入、弹出序列
题目描述输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否可能为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1,2,3,4,5是某栈的压入顺序,序列4,5,3,2,1是该压栈序列对应的一个弹出序列,但4,3,5,1,2就不可能是该压栈序列的弹出序列。(注意:这两个序列的长度是相等的)前言现在我越来越觉得变成的时候思想很重要,不是编完了就完事了,而应该清楚自己是怎么想...原创 2019-03-18 20:05:29 · 108 阅读 · 0 评论 -
连续子数组的最大和
题目描述HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。给一个数组,返回它的最大连续子序列...原创 2019-04-03 23:49:07 · 80 阅读 · 0 评论 -
leetcode: 20. Valid Parentheses
题目:Given a string containing just the characters '(', ')', '{', '}', '[' and ']', determine if the input string is valid.An input string is valid if:Open brackets must be closed by the same type ...原创 2019-09-24 16:54:47 · 69 阅读 · 0 评论 -
leetcode:844. Backspace String Compare
题目:Given two strings S and T, return if they are equal when both are typed into empty text editors. # means a backspace character.Example 1:Input: S = "ab#c", T = "ad#c"Output: trueExplanation:...原创 2019-09-19 19:58:49 · 133 阅读 · 0 评论 -
leetcode:25. Reverse Nodes in k-Group
题目:Given a linked list, reverse the nodes of a linked list k at a time and return its modified list.k is a positive integer and is less than or equal to the length of the linked list. If the number...原创 2019-09-15 17:49:07 · 68 阅读 · 0 评论 -
剑指offer:把数组排成最小的数和整数中 1 出现的个数
题目描述输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。分析这题肯定要使用排序,但是要怎么使用排序我想了好久都没有想明白,后来看了答案,才发现原来还可以这样。积累经验,代码倒是很简单,注意一下 sort 的用法就行了。static bool cmp(int a, ...原创 2019-08-12 15:52:28 · 72 阅读 · 0 评论 -
剑指 offer:把字符串转换成整数、数组中重复的数字
把字符串转换成整数题目描述将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0。分析这题比较简单,主要就是分析开头是不是符号然后例外情况,其他的没什么。就是记录一下。代码如下:int StrToInt(string str) {...原创 2019-08-13 16:39:08 · 150 阅读 · 0 评论 -
剑指 offer:扑克牌顺子、孩子们的游戏、不用加减乘除做加法
扑克牌顺子题目描述LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张_)…他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子…LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K为13...原创 2019-06-02 21:32:43 · 115 阅读 · 0 评论 -
剑指 offer:两个链表的第一个公共节点、数字在排序数组中的个数、二叉树的深度
题目描述输入两个链表,找出它们的第一个公共结点。分析首先要明白公共节点的含义:即两个链表从某个节点开始重合,重合的第一个节点即为第一个公共节点。那么最直接的想法就是从后往前推,找到第一个不相同的节点,它的 next 即为我们想要的公共节点。这种方法要用栈。可以从前往后吗?其实也是可以的,先求出两个链表的长度 len1,len2,然后对较长的那个链表,先遍历 | len2-len1 | 次...原创 2019-04-22 15:40:38 · 87 阅读 · 0 评论 -
剑指 offer:字符串的排列
题目描述输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。输入描述:输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。分析这道题包括了重复字符的情况,会稍微复杂一点。先考虑无重复字符的情况。如果会回溯算法的话,那么这道题会很简单。或者说深度...原创 2019-04-09 21:20:40 · 70 阅读 · 0 评论 -
剑指offer:数组中出现次数超过一半的数字和最小的 k个数
数组中出现次数超过一半的数字数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。分析遍历数组,使用 map 计数,超过一半即返回。有个问题:时间复杂度应该怎么算。int MoreThanHalfNum_Solution(vector&...原创 2019-04-02 15:26:52 · 89 阅读 · 0 评论 -
剑指 offer:二叉树中和为某一值的路径
题目描述输入一颗二叉树的跟节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。(注意: 在返回值的list中,数组长度大的数组靠前)分析树经常是和递归联系在一起的,所以,这题也要用到递归算法。问题就在于如何保存元素。我最开始的想法是用栈来保存路径节点,但在最后将栈存到 vector 中的时候出现了问题:要将栈中所...原创 2019-03-23 19:58:34 · 63 阅读 · 0 评论 -
剑指 offer:替换空格
题目描述请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。我的思路:就很直接地从前往后遍历,没遇到一个空格,就先将其后面的字符向后移动,再将空格替换。代码如下:class Solution {public: void replaceSpace(char *str,int lengt...原创 2019-02-24 15:54:11 · 99 阅读 · 0 评论 -
剑指 offer:二维数组中的查找
题目描述在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。分析:要充分利用数组的递增特点。我的思路:先将数组向右开始遍历,若失败,则改为向下,同时失败那点的右下方全都没必要再访问(因为都比失败的那个点大,也即比目标点大)。若向下遍历失败则向左,再向右,再...原创 2019-02-23 21:04:11 · 68 阅读 · 0 评论 -
牛客网 地下迷宫
牛客网 地下迷宫题目描述 小青蛙有一天不小心落入了一个地下迷宫,小青蛙希望用自己仅剩的体力值P跳出这个地下迷宫。为了让问题简单,假设这是一个n*m的格子迷宫,迷宫每个位置为0或者1,0代表这个位置有障碍物,小青蛙达到不了这个位置;1代表小青蛙可以达到的位置。小青蛙初始在(0,0)位置,地下迷宫的出口在(0,m-1)(保证这两个位置都是1,并且保证一定有起点到终点可达的路径),小青蛙在迷宫中...原创 2018-08-15 22:12:56 · 260 阅读 · 0 评论 -
牛客网 进制转换
牛客网 进制转换题目描述 给定一个十进制数M,以及需要转换的进制数N。将十进制数M转化为N进制数 输入描述: 输入为一行,M(32位整数)、N(2 ≤ N ≤ 16),以空格隔开。 输出描述: 为每个测试实例输出转换后的数,每个输出占一行。如果N大于9,则对应的数字规则参考16进制(比如,10用A表示,等等)分析:较简单,主要学到了用表映射的方法,而不是if…else…来做 ...原创 2018-08-13 10:37:55 · 671 阅读 · 0 评论 -
牛客网 素数对
牛客网 素数对题目描述 给定一个正整数,编写程序计算有多少对质数的和等于输入的这个正整数,并输出结果。输入值小于1000。 如,输入为10, 程序应该输出结果为2。(共有两对质数的和为10,分别为(5,5),(3,7)) 输入描述: 输入包括一个整数n,(3 ≤ n < 1000) 输出描述: 输出对数分析:水题,考察素数。记住素数从2开始即可import ma...原创 2018-08-08 10:12:10 · 195 阅读 · 0 评论 -
牛客网 数字和为sum的方法
牛客网 数字和为sum的方法题目描述 给定一个有n个正整数的数组A和一个整数sum,求选择数组A中部分数字和为sum的方案数。 当两种选取方案有一个数字的下标不一样,我们就认为是不同的组成方案。 输入描述: 输入为两行: 第一行为两个正整数n(1 ≤ n ≤ 1000),sum(1 ≤ sum ≤ 1000) ...原创 2018-08-12 11:31:09 · 504 阅读 · 0 评论 -
牛客网 字典序
牛客网 字典序给定整数n和m, 将1到n的这n个整数按字典序排列之后, 求其中的第m个数。 对于n=11, m=4, 按字典序排列依次为1, 10, 11, 2, 3, 4, 5, 6, 7, 8, 9, 因此第4个数是2. 对于n=200, m=25, 按字典序排列依次为1 10 100 101 102 103 104 105 106 107 108 109 11 110 111 1...原创 2018-08-03 10:05:34 · 543 阅读 · 0 评论 -
牛客网 geohash编码
牛客网 geohash编码题目描述 geohash编码:geohash常用于将二维的经纬度转换为字符串,分为两步:第一步是经纬度的二进制编码,第二步是base32转码。 此题考察纬度的二进制编码:算法对纬度[-90, 90]通过二分法进行无限逼近(取决于所需精度,本题精度为6)。注意,本题进行二分法逼近过程中只采用向下取整来进行二分,针对二分中间值属于右区间。算法举例如下: 针对纬度为...原创 2018-08-07 10:04:36 · 186 阅读 · 0 评论 -
牛客网 字符串中找出最长的数字串
题目描述 读入一个字符串str,输出字符串str中的连续最长的数字串 输入描述: 个测试输入包含1个测试用例,一个字符串str,长度不超过255。 输出描述: 在一行内输出str中里连续最长的数字串。代码:s = raw_input()n = len(s)maxCnt = 0i = 0l = r = 0lt = rt = 0while(i < n): ...原创 2018-08-11 10:54:59 · 264 阅读 · 0 评论 -
牛客网 倒置字符串
牛客网 倒置字符串题目描述 将一句话的单词进行倒置,标点不倒置。比如 I like beijing. 经过函数后变为:beijing. like I 输入描述: 每个测试输入包含1个测试用例: I like beijing. 输入用例长度不超过100 输出描述: 依次输出倒置之后的字符串,以空格分割分析:水题,只需知道如何倒置字符串及如何输出列表中元素即可s = raw...原创 2018-08-11 10:19:59 · 434 阅读 · 0 评论 -
# 牛客网 末尾0的个数
牛客网 末尾0的个数题目描述 输入一个正整数n,求n!(即阶乘)末尾有多少个0? 比如: n = 10; n! = 3628800,所以答案为2 输入描述: 输入为一行,n(1 ≤ n ≤ 1000) 输出描述: 输出一个整数,即题目所求分析:本题可理解为从1到n的n个数中有多少个2*5,因为因子为2的数目必然比因子为5的数目多,所以只要看有多少个5即可,又只有5的倍数有5这个...原创 2018-08-14 09:44:43 · 167 阅读 · 0 评论 -
删除公共字符
删除公共字符题目描述 输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。例如,输入”They are students.”和”aeiou”,则删除之后的第一个字符串变成”Thy r stdnts.” 输入描述: 每个测试输入包含2个字符串 输出描述: 输出删除后的字符串分析:水题,直接写即可def isBelong(a, s): for i in range...原创 2018-08-10 10:25:26 · 113 阅读 · 0 评论 -
求和
求和题目描述 输入两个整数 n 和 m,从数列1,2,3…….n 中随意取几个数,使其和等于 m ,要求将其中所有的可能组合列出来 输入描述: 每个测试输入包含2个整数,n和m 输出描述: 按每个组合的字典序排列输出,每行输出一种组合分析:用递归,或者叫深度优先,一层一层往下,若能得到最终结果,则栈中的数字全都有效,否则栈中的数字都会被弹出,代码如下:stack = []...原创 2018-08-09 10:57:51 · 414 阅读 · 1 评论