牛客网算法
剑指Offer等算法思维解析
张茂祯
嗯,随缘了
展开
-
【剑指offer】镜像二叉树
题目描述请实现一个函数,用来判断一棵二叉树是不是对称的。注意,如果一个二叉树同此二叉树的镜像是同样的,定义其为对称的。思路:1. L->val == R->val2. L->left->val == R->right->val3. L->right->val == R->left->val设置一个递归函数,isSame(r1, r2),表示如果对称,返回true,否则返回false递归终止条件:r1 == null &&a原创 2020-11-12 08:47:48 · 59 阅读 · 0 评论 -
【剑指Offer】二叉树的下一个结点
题目描述:给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针。红色数字是中序遍历的顺序。接下来,假设如果当前节点分别是1,2,…,7发现规律。1 => 2 // 显然下一结点是 1 的父亲结点2 => 3 // 下一节点是当前结点右孩子的左孩子结点,其实你也应该想到了,应该是一直到左孩子为空的那个结点3 => 4 // 跟 2 的情况相似,当前结点右孩子结点的左孩子为空的那个结点4 =>原创 2020-11-10 15:48:36 · 75 阅读 · 0 评论 -
【剑指Offer】52.正则表达式
题目描述请实现一个函数用来匹配包括’.‘和’‘的正则表达式。模式中的字符’.‘表示任意一个字符,而’'表示它前面的字符可以出现任意次(包含0次)。 在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"abaca"匹配,但是与"aa.a"和"ab*a"均不匹配方法一:递归自顶向下:假设主串为s,长度为sn,模式串为p,长度为pn,位于模式串p当前的第i位来说,有‘正常字符’、‘*’、‘.’三种情况。如果p[i]为正常字符,那么我们看s[i]是否等于p[i],如原创 2020-11-09 14:02:21 · 163 阅读 · 0 评论 -
【剑指Offer】51.构建乘积数组
题目描述给定一个数组A[0,1,…,n-1],请构建一个数组B[0,1,…,n-1],其中B中的元素B[i]=A[0]A[1]…*A[i-1]A[i+1]…*A[n-1]。不能使用除法。(注意:规定B[0] = A[1] * A[2] * … * A[n-1],B[n-1] = A[0] * A[1] * … * A[n-2];)对于A长度为1的情况,B无意义,故而无法构建,因此该情况不会存在。解题:两次循环第一次循环:求出B[i]的左边乘积和,Left[i-1],放入B[i]第二次循环,求出原创 2020-11-07 15:09:37 · 73 阅读 · 0 评论 -
【剑指Offer】50.数组中重复的数字
题目描述在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中第一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。返回描述:如果数组中有重复的数字,函数返回true,否则返回false。如果数组中有重复的数字,把重复的数字放到参数duplication[0]中。(ps:duplication已经初始化,可以直接赋值使用。)方法一:哈希值+遍原创 2020-11-06 16:02:08 · 67 阅读 · 0 评论 -
【剑指Offer】49.把字符串转成整数
题目描述将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0输入描述。输入一个字符串,包括数字字母符号,可以为空返回值描述:如果是合法的数值表达则返回该数字,否则返回0拓展:char字符’0’在ASCII中是481,2,3,…,9分别是:49,50,51,…,57.想得到对应字符串的数字,需要使用 char-‘0’思路:首先获取字符串的整负标记。从字符串首开始取,每次获取新字符,将新字符转换为0~9的值并与ret*1原创 2020-11-06 15:03:36 · 78 阅读 · 0 评论 -
【剑指Offer】48.不用加减乘除做加法
题目描述写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。按位与&,按位或|, 按位异或^补码计算机中存整数n是用补码存的。如果n为正数,则原码=反码=补码如果n为负数,则补码=反码+1方法:位运算使用位运算来实现两数的加法。设两数字的二进制形式a, b,其求和s = a + b, a(i)代表a的二进制第i位,则分为以下四种情况:观察发现,无进位就是按位异或(^)结果,进位就是与运算(&)结果,但是需要左移一位,因为进位影响下一位运原创 2020-11-05 17:04:00 · 72 阅读 · 0 评论 -
【剑指Offer】47.求1+2+3+...+n
题目描述求1+2+3+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。方法:递归变形-不能使用if,使用&&,当左边为false时,右边不执行。 public int Sum_Solution(int n) { boolean f = (n!=0) && (n+=Sum_Solution(n-1))!=0; return n; }...原创 2020-11-05 16:16:52 · 72 阅读 · 0 评论 -
【剑指Offer】46.圆圈中剩下最后剩下的数)
题目描述每年六一儿童节,牛客都会准备一些小礼物去看望孤儿院的小朋友,今年亦是如此。HF作为牛客的资深元老,自然也准备了一些小游戏。其中,有个游戏是这样的:首先,让小朋友们围成一个大圈。然后,他随机指定一个数m,让编号为0的小朋友开始报数。每次喊到m-1的那个小朋友要出列唱首歌,然后可以在礼品箱中任意的挑选礼物,并且不再回到圈中,从他的下一个小朋友开始,继续0…m-1报数…这样下去…直到剩下最后一个小朋友,可以不用表演,并且拿到牛客名贵的“名侦探柯南”典藏版(名额有限哦!!_)。请你试着想下,哪个小朋友会得原创 2020-11-05 15:50:08 · 90 阅读 · 0 评论 -
【剑指Offer】45.扑克牌顺子
题目描述LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张_)…他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子…LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K为13。上面的5张牌就可以变成“1,2,3,4,5”(大小王分别看作2和4),“So Lucky!”。LL决定去买体育彩票啦。 现原创 2020-11-05 14:35:48 · 97 阅读 · 0 评论 -
【剑指Offer】42.和为S的两个数字
题目描述输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。方法一:哈希法求a+b=sum,如果已知a,那么b=sum-a所以可以先将b添加入哈希中,然后遍历一遍数组设为a,在哈希中寻找是否存在sum-a,然后再更新乘积最小值。class Solution {public: vector<int> FindNumbersWithSum(vector<int> array,int sum原创 2020-11-03 16:54:05 · 75 阅读 · 0 评论 -
【剑指Offer】和为S的连续正数序列
题目描述找出所有和为S的连续正数序列? Good Luck!方法一:暴力破解:时间复杂度:O(n3)空间复杂度:O(1)class Solution {public: vector<vector<int> > FindContinuousSequence(int sum) { vector<vector<int>> ret; // 左边界 for (int i=1; i<=sum/2; ++i) {原创 2020-11-03 16:25:00 · 96 阅读 · 0 评论 -
【剑指Offer】40.数组中只出现一次的数字
题目描述:一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。方法一:哈希法遍历一遍数组,用map记录出现的次数,再遍历一遍数组,找出出现1次的数字时间复杂度:O(n)空间复杂度:O(n) public void FindNumsAppearOnce(int [] array,int num1[] , int num2[]) { Map<Integer,Integer> map = new LinkedHashMap(原创 2020-11-03 15:19:46 · 82 阅读 · 0 评论 -
【剑指Offer】39.平衡二叉树
题目描述输入一棵二叉树,判断该二叉树是否是平衡二叉树。在这里,我们只需要考虑其平衡性,不需要考虑其是不是排序二叉树知识点:数、递归利用后序遍历:左子树、右子树、根节点,先递归到叶子节点,然后回溯判断条件判断树高的代码: public int depth(TreeNode root){ if (root == null) return 0; int lh = depth(root.left); int rh = depth(root.rig原创 2020-11-02 20:25:14 · 60 阅读 · 0 评论 -
【剑指Offer】36.两个链表的第一个公共结点
题目描述输入两个链表,找出它们的第一个公共结点。(注意因为传入数据是链表,所以错误测试数据的提示是用其他方式显示的,保证传入数据是正确的)方法一:暴力破解迭代两次方法二:双指针法如果A和B链表长度相同,那么当指针p1,p2同时向后走,当p1==p2时说明找到共同节点那么A指针和B指针同时向后移动,当p1或p2走到null时,使其获得另一个节点的头结点。短的链表节点先走到null,获得长的头结点,长的链表节点走到null获得短的头结点时,两个节点刚刚好处于同步等长链表的状态。共同节原创 2020-10-30 19:02:34 · 131 阅读 · 1 评论 -
【剑指Offer】34.第一个只出现一次的字符
题目描述在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写).(从0开始计数)**知识点:**哈希方法一:哈希法遍历一遍自负循环,统计每个字符出现的次数。然后再遍历一遍字符串,找出答案时间复杂度O(2n),需要遍历两次字符串空间复杂度:O(n)class Solution {public: int FirstNotRepeatingChar(string str) {原创 2020-10-30 14:35:20 · 67 阅读 · 0 评论 -
【剑指Offer】33.丑数
题目描述把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。思路:丑数由于只包含2、3、5,因此可以写为,2x × 3y × 5z如果x=y=z,那么最小的丑数一定是乘2的,但存在x>y>z的情况。使用三个指针来记录当前乘2、乘3、乘5后得到的最小值,得到最小值后,把该指针+1即,找到2x × 3y × 5z 可以得到的最小值,每次x,y,z中,最少有一原创 2020-10-30 14:29:55 · 68 阅读 · 0 评论 -
【剑指Offer】32.把数组排成最小的数
题目描述输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。知识点:数组,全排列,排序,贪心方法一:暴力破解假设n个整数的索引值为[0,1,…,n-1],对这n个索引全拍了,再对每次全排列进行一次组织结果,选取最小的值为答案。时间复杂度:O(n*n!),全排列时间复杂度为N!,每次排列结果需要遍历一次nums数组空间复杂度:O(1)代码为:class So原创 2020-10-29 15:25:32 · 83 阅读 · 0 评论 -
【剑指Offer】30.连续子数组最大和
题目描述:求一串序列中子序列的最大值,序列中存在负数。如{6, -3, -2,7, -15, 1, 2, 2},连续子向量最大和为8(第0个开始,第3个为止)子向量长度最少是1方法一:动态规划定义dp[i]表示以i为结尾的连续数组的最大和。所以最终要求dp[n-1]状态转移方程:dp[i] = max(array[i-1], dp[i-1] + array)思路:判断 array[0] + array[1]+…+array[i] < array[i] ? true : fals原创 2020-10-28 16:10:31 · 74 阅读 · 0 评论 -
【剑指Offer】29.最小的K个数
题目描述:输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4。、知识点:数组,堆,快排我的思路:k次冒泡排序,将前k个值添加到ArrayList中。 public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) { ArrayList arrayList = new ArrayList();原创 2020-10-27 14:48:33 · 96 阅读 · 0 评论