自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(41)
  • 收藏
  • 关注

原创 剑指 Offer 28. 对称的二叉树

2020-06-281.题目描述请实现一个函数,用来判断一棵二叉树是不是对称的。如果一棵二叉树和它的镜像一样,那么它是对称的。2.题解使用递归来进行求解,我们判断两棵树r1和r2是否镜像对称,是判断r1的左子树和r2的右子树以及r1的右子树和r2的左子树是否对称即可3.代码/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * T

2020-06-28 21:14:25 113

原创 剑指 Offer 31. 栈的压入、弹出序列

2020-06-281.题目描述输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如,序列 {1,2,3,4,5} 是某栈的压栈序列,序列 {4,5,3,2,1} 是该压栈序列对应的一个弹出序列,但 {4,3,5,1,2} 就不可能是该压栈序列的弹出序列。2.题解对于pushed的每一个元素先入栈,如果栈顶元素始终和poped的元素相等的话,则一直出栈即可3.代码class Solution {public: b

2020-06-28 18:07:04 85

原创 剑指 Offer 32 - III. 从上到下打印二叉树 III

2020-06-281.题目描述请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。2.题解1.偶数层时对vector逆序2.偶数层时插在vector前面3.代码/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNod

2020-06-28 17:30:42 83

原创 剑指 Offer 18. 删除链表的节点

2020-06-281.题目描述给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。返回删除后的链表的头节点。2.题解3.代码/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */class Solution {p

2020-06-28 17:13:47 77

原创 剑指 Offer 42. 连续子数组的最大和

2020-06-281.题目描述输入一个整型数组,数组里有正数也有负数。数组中的一个或连续多个整数组成一个子数组。求所有子数组的和的最大值。2.题解1.暴力法(不符合O(n)的时间复杂度)2.动态规划,其中f(n)表示以num[n]结尾的子数组和的最大值3.代码class Solution {public: int maxSubArray(vector<int>& nums) { int len=nums.size(); ve

2020-06-28 16:59:16 202

原创 剑指 Offer 50. 第一个只出现一次的字符

2020-06-281.题目描述在字符串 s 中找出第一个只出现一次的字符。如果没有,返回一个单空格。 s 只包含小写字母。2.题解由于只有小写字母,直接使用数组下标即可3.代码class Solution {public: char firstUniqChar(string s) { if (s=="") return ' '; int len=s.size(); int x[26]={0}; for (int i=

2020-06-28 16:43:28 95

原创 剑指 Offer 62. 圆圈中最后剩下的数字

2020-06-281.题目描述0,1,,n-1这n个数字排成一个圆圈,从数字0开始,每次从这个圆圈里删除第m个数字。求出这个圆圈里剩下的最后一个数字。2.题解1.循环链表:超时2.公式法:注意这里表示幸存在这一轮的的人的下标位置class Solution {public: struct LinkNode{ LinkNode* next; int val; }; int lastRemaining(int n, int m) {

2020-06-28 16:34:16 232

原创 剑指 Offer 63. 股票的最大利润

2020-06-241.题目描述假设把某股票的价格按照时间先后顺序存储在数组中,请问买卖该股票一次可能获得的最大利润是多少?2.题解1.暴力2.在当前时间卖可以获得的利润为当前的价格-之前价格的最小值,取所有时间可以获取利润的最小值3.代码class Solution {public: int maxProfit(vector<int>& prices) { int len=prices.size(); if (!len) re

2020-06-24 12:24:36 105

原创 剑指 Offer 52. 两个链表的第一个公共节点

2020-06-241.题目描述输入两个链表,找出它们的第一个公共节点。2.题解1.暴力搜索,看链表1的每个节点是否在链表2中出现2.让长的链表先走3.代码/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */class Solu

2020-06-24 12:04:18 96

原创 剑指 Offer 32 - I. 从上到下打印二叉树

2020-06-231.题目描述下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印。2.题解广度优先搜索即可3.代码/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {}

2020-06-23 21:49:05 134

原创 剑指 Offer 21. 调整数组顺序使奇数位于偶数前面

2020-06-231.题目描述输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分。2.题解双指针,从前往后找到第一个偶数,从后向前找到第一个奇数,然后进行交换即可。3.代码class Solution {public: vector<int> exchange(vector<int>& nums) { int len=nums.size(); if (

2020-06-23 10:20:00 148

原创 剑指 Offer 57. 和为s的两个数字

2020-06-231.题目描述难度简单22收藏分享切换为英文关注反馈输入一个递增排序的数组和一个数字s,在数组中查找两个数,使得它们的和正好是s。如果有多对数字的和等于s,则输出任意一对即可。2.题解使用双指针即可3.代码class Solution {public: vector<int> twoSum(vector<int>& nums, int target) { int len=nums.size(); i

2020-06-23 10:08:35 147

原创 剑指 Offer 03. 数组中重复的数字

2020-06-231.题目描述在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。2.题解1.借助于map或者数组统计数字出现的次数2.使下标与其值一一对应,为节省空间可以进行交换,看是否冲突即可3.代码class Solution {public: int findRepeatNumber(vector<int>& num

2020-06-23 09:55:17 71

原创 剑指 Offer 39. 数组中出现次数超过一半的数字

2020-06-231.题目描述数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。2.题解该数出现的次数比剩下所有数出现的次数之和还要多3.代码class Solution {public: int majorityElement(vector<int>& nums) { int len=nums.size(); int cnt=1,number=nums[0]; for (int i=1;i<l

2020-06-23 09:26:18 80

原创 剑指 Offer 47. 礼物的最大价值

2020-06-231.题目描述在一个 m*n 的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于 0)。你可以从棋盘的左上角开始拿格子里的礼物,并每次向右或者向下移动一格、直到到达棋盘的右下角。给定一个棋盘及其上面的礼物的价值,请计算你最多能拿到多少价值的礼物?2.题解1.递归:超时2.动态规划3.代码class Solution {public: int maxValue(vector<vector<int>>& grid) {

2020-06-23 09:02:37 133

原创 剑指 Offer 68 - I. 二叉搜索树的最近公共祖先

2020-06-221.题目描述给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。2.题解递归求解即可,可以利用二叉搜索树的特征 ,其左子树值均小于根,其右子树值均大于根。3.代码/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : va

2020-06-22 21:05:55 111

原创 剑指 Offer 07. 重建二叉树

2020-06-221.题目描述输入某二叉树的前序遍历和中序遍历的结果,请重建该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。2.题解递归求解即可3.代码/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), lef

2020-06-22 20:55:52 105

原创 剑指 Offer 68 - II. 二叉树的最近公共祖先

2020-06-221.题目描述给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。2.题解递归3.代码/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; *

2020-06-22 18:45:28 100

原创 剑指 Offer 32 - II. 从上到下打印二叉树 II

2020-06-221.题目描述从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。2.题解广度优先搜索,即层次遍历即可3.代码/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), r

2020-06-22 18:21:16 64

原创 09. 用两个栈实现队列

2020-06-221.题目描述用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )2.题解一个栈用来输入,一个栈用来输出入栈:直接入栈1即可出栈:如果栈2为空,则将栈1所有元素放入栈2,并输出栈2栈顶元素,如果栈2不为空,直接出栈2即可3.代码class CQueue {public: CQueue() {

2020-06-22 16:11:30 103

原创 56 - I. 数组中数字出现的次数

202–06-221.题目描述一个整型数组 nums 里除两个数字之外,其他数字都出现了两次。请写程序找出这两个只出现一次的数字。要求时间复杂度是O(n),空间复杂度是O(1)。2.题解位运算3.代码class Solution {public: vector<int> singleNumbers(vector<int>& nums) { int len=nums.size(); int ans=0;

2020-06-22 16:03:55 70

原创 54. 二叉搜索树的第k大节点

2020-06-221.题目描述给定一棵二叉搜索树,请找出其中第k大的节点。2.题解中序遍历二叉搜索树即为升序的结果,将其存储在vector中,最后进行输出即可。3.代码/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left

2020-06-22 13:49:30 72

原创 15. 二进制中1的个数

2020-06-221.题目描述在这里插入代码片难度简单31收藏分享切换为英文关注反馈请实现一个函数,输入一个整数,输出该数二进制表示中 1 的个数。例如,把 9 表示成二进制是 1001,有 2 位是 1。因此,如果输入 9,则该函数输出 2。2.题解1.计算其二进制表示,然后再进行计数2.使用位运算n&(n-1)能够去除n末尾的一个13.代码class Solution {public: int hammingWeight(uint32_t n) {

2020-06-22 13:23:30 95

原创 25. 合并两个排序的链表

2020-06-221.题目描述输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。2.题解直接进行合并即可,注意这里的pre指针要进行更新3.代码/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */clas

2020-06-22 13:18:41 92

原创 24. 反转链表

2020-06-221.题目描述定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。2.解答直接进行反转即可,注意不要让链表断了即可3.代码/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */class Sol

2020-06-22 12:33:52 70

原创 06. 从尾到头打印链表

2020-06-221.题目描述输入一个链表的头节点,从尾到头反过来返回每个节点的值(用数组返回)。2.题解1.放入vector中,然后reverse2.将链表反转3.代码/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode(int x) : val(x), next(NULL) {} * }; */cl

2020-06-22 12:31:58 69

原创 05. 替换空格

2020-06-221.题目描述请实现一个函数,把字符串 s 中的每个空格替换成"%20"。2.题解1.res+="%20";2.res.push_back('%'); res.push_back('2'); res.push_back('0');class Solution {public: string replaceSpace(string s) { string res=""; int l=s.length(); fo

2020-06-22 12:24:39 98

转载 C语言中的文件包含

2020-06-22参考https://www.cnblogs.com/Bonker/p/3548276.html

2020-06-22 09:56:04 622

原创 27. 二叉树的镜像

2020-06-201.题目描述请完成一个函数,输入一个二叉树,该函数输出它的镜像。2.题解1.递归2.非递归(队列)3.代码class Solution {public: TreeNode* mirrorTree(TreeNode* root) { if (!root) return NULL; TreeNode* t1=mirrorTree(root->right); TreeNode* t2=mirrorTree(roo

2020-06-20 23:00:21 127 1

原创 22. 链表中倒数第k个节点

2020-06-201.题目描述难度简单46收藏分享切换为英文关注反馈输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。例如,一个链表有6个节点,从头节点开始,它们的值依次是1、2、3、4、5、6。这个链表的倒数第3个节点是值为4的节点。2.题解1.首先统计链表的长度cnt,然后得到正数第cnt-k+1个即可2.双指针法3.代码class Solution {public: ListNode* getKthFr

2020-06-20 22:43:40 126

原创 55 - I. 二叉树的深度

2020-06-201.题目描述难度简单25收藏分享切换为英文关注反馈输入一棵二叉树的根节点,求该树的深度。从根节点到叶节点依次经过的节点(含根、叶节点)形成树的一条路径,最长路径的长度为树的深度。2.题解1.递归,树的深度等于左右子树最大的深度+12.层次遍历,求出当前树的层数即可3.代码class Solution {public: int maxDepth(TreeNode* root) { if (root==NULL) return 0;

2020-06-20 15:47:36 95

原创 56 - II. 数组中数字出现的次数 II

2020-06-191.题目描述在一个数组 nums 中除一个数字只出现一次之外,其他数字都出现了三次。请找出那个只出现一次的数字2.解答1.统计每个数出现的次数2.将元素放入set中,进行计算,在求和的时候为避免溢出,要用long long int3.位运算,对于每一位而言,统计所有数该位为1的数的个数,如果不是3的倍数,表明结果在该位上为1.3.代码class Solution {public: int singleNumber(vector<int>&

2020-06-19 22:31:15 96

原创 面试题58 - II. 左旋转字符串

2020-06-181.题目描述字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"2.题解1.空间换时间:将左右部分各放在string中再进行拼接2.时间换空间:对字符串进行三次翻转3.代码class Solution {public: string reverseLeftWords(string s,int n) {

2020-06-18 16:32:29 91

原创 面试题64. 求1+2+…+n

2020-06-181.题目描述求 1+2+...+n ,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。2.题解1.递归+逻辑2.使用俄罗斯农民算法,参考https://blog.csdn.net/iteye_4501/article/details/816821603.代码class Solution {public: int sumNums(int n) { n&&(n+=

2020-06-18 15:13:18 120

原创 vtkpolydata图形着色

2020-06-10颜色可以直接作为一种标量属性数据,设置到相应的点或者单元数据中,这是最直接的一种图形着色方式。1.需求根据vtkLookupTable为点设置相对应的颜色,在这里我们需要首先为点设置标量属性值。2.代码#include <vtkSmartPointer.h>#include <vtkPolyData.h>#include <vtkFloatArray.h>#include <vtkCellData.h>#include

2020-06-10 11:52:41 2715

原创 vtk基本数据结构

2020-06-10数据对象被组织成一种结构并且被赋予相应的属性值时就形成数据集(Dataset)。VTK里数据集对应的类是vtkDataSet,该类从vtkDataObject直接派生。vtkDataSet由两个部分组成,即组织结构(Organizing Structure)以及与组织结构相关联的属性数据(Attribute Data)。vtkDataSet的组织结构由拓扑结构(Topology)和几何结构(Geometry)两部分组成。拓扑结构描述了物体的构成形式,几何结构描述了物体的空间位置

2020-06-10 11:30:41 847

原创 35. 搜索插入位置

2020-06-091.题目描述搜索插入位置2.题解二分查找即可。3.代码class Solution {public: int searchInsert(vector<int>& nums, int target) { int len=nums.size(); int l=0,h=len-1; while (l<=h){ int mid=(l+h)/2; if

2020-06-09 21:43:12 106

原创 1203. 项目管理

2020-06-091.题目描述项目管理2.题解由于题目要求同一小组的项目,排序后在列表中彼此相邻1.首先进行组间排序,有拓扑序列则转向22.其次进行组内排序,有拓扑序列则输出结果3.代码class Solution {public: vector<int> sortItems(int n, int m, vector<int>& group, vector<vector<int>>& beforeItems) {

2020-06-09 14:46:20 214

原创 329. 矩阵中的最长递增路径

2020-06-091.题目描述矩阵中的最长递增路径2.题解在这里我们可以将其视作有向图,如果当前的数比其四周位置上的数要小的话,就构建一条从当前数指向其周围的边,要求得最长的递增路径,那么其一定是从入度为0的点开始的,我们可以按照拓扑排序的逻辑,当当前点的入度为0时,则入队列,同时将与其相邻并且值比它大的数的入度减1,到同一点的路径不只一条,我们取其最大值。3.代码class Solution {public: int longestIncreasingPath(vecto

2020-06-09 09:38:45 188

原创 208. 实现 Trie (前缀树)

2020-06-051.题目描述实现 Trie (前缀树)2.题解由于题目中所有的输入都是由小写字母 a-z 构成的,我们可以将每个节点看作是有26个分支。3.代码class Trie {public: /** Initialize your data structure here. */ Trie():root(new TrieNode()) { } /** Inserts a word into the trie. */ void i

2020-06-05 15:03:44 152

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除