自定义博客皮肤VIP专享

*博客头图:

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

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

博客底图:

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

栏目图:

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

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(292)
  • 资源 (4)
  • 收藏
  • 关注

原创 【Leetcode】99. Recover Binary Search Tree( Morris 遍历)

题目地址:Recover Binary Search Tree题意是一个二分查找树种的两个元素位置调换,在不改变结构的情况下,恢复这个树。解法1;根据平衡二叉树的性质,中跟遍历得到的应该是一个递增序列。class Solution { public void recoverTree(TreeNode root) { List<Integer> vals...

2020-04-13 21:13:52 242

原创 【Leetcode】98. Validate Binary Search Tree

题目地址:98. Validate Binary Search Tree题意:判断一个二叉树是否是平衡二叉树。平衡二叉树的性质就是中序遍历得到的是一个递增的数组。很容易就写出下面方法:class Solution { public boolean isValidBST(TreeNode root) { if(root==null)return true; ...

2020-04-12 23:54:48 198

原创 【Leetcode】889. Construct Binary Tree from Preorder and Postorder Traversal

题目链接:889. Construct Binary Tree from Preorder and Postorder Traversal根据前序和后序建立一个二叉树,注意这种情况是不能唯一确定一棵树的,所以返回任意一个即可。class Solution {public: TreeNode* constructFromPrePost(vector<int>& pr...

2020-03-30 09:36:20 214

原创 【Leetcode】105. Construct Binary Tree from Preorder and Inorder Traversal

题目地址:105. Construct Binary Tree from Preorder and Inorder Traversal题意:根据前跟和中跟建立二叉树。.递归方法:class Solution {public: TreeNode* buildTree(vector<int>& preorder, vector<int>& ino...

2020-03-30 09:29:44 140

原创 【Leetcode】124. Binary Tree Maximum Path Sum

Given a non-empty binary tree, find the maximum path sum.For this problem, a path is defined as any sequence of nodes from some starting node to any node in the tree along the parent-child connection...

2020-03-13 19:15:47 97

原创 【剑指OFFER】删除链表中重复的结点

题目描述在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5非递归:class Solution {public: ListNode* deleteDuplication(ListNode* pHead) {...

2020-01-10 16:41:04 155

原创 【剑指OFFER】字符流中第一个只出现一次的字符

题目描述请实现一个函数用来找出字符流中第一个只出现一次的字符。例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是"g"。当从该字符流中读出前六个字符“google"时,第一个只出现一次的字符是"l"。输出描述:如果当前字符流没有存在出现一次的字符,返回#字符。class Solution{public: string s; char cnt[257]...

2019-12-27 00:17:00 81

原创 【剑指OFFER】表示数值的字符串

题目描述请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100",“5e2”,"-123",“3.1416"和”-1E-16"都表示数值。 但是"12e",“1a3.14”,“1.2.3”,"±5"和"12e+4.3"都不是。class Solution {public: bool isNumeric(char* string) { ...

2019-12-26 21:49:54 99

原创 【剑指OFFER】正则表达式匹配

题目描述请实现一个函数用来匹配包括’.‘和’‘的正则表达式。模式中的字符’.‘表示任意一个字符,而’'表示它前面的字符可以出现任意次(包含0次)。 在本题中,匹配是指字符串的所有字符匹配整个模式。例如,字符串"aaa"与模式"a.a"和"abaca"匹配,但是与"aa.a"和"ab*a"均不匹配class Solution {public: bool match(char* str,...

2019-11-16 20:48:52 104

原创 【剑指OFFER】构建乘积数组

题目描述给定一个数组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]。不能使用除法。class Solution {public: vector<int> multiply(const vector<int>& A) { vector&...

2019-11-16 15:54:28 87

原创 【剑指OFFER】数组中重复的数字

题目描述在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。思路:不开辟新的空间,利用负数标记访问的数字。class Solution {public: bool du...

2019-11-06 20:38:34 91

原创 【剑指OFFER】把字符串转换成一个整数

题目描述将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0输入描述:输入一个字符串,包括数字字母符号,可以为空输出描述:如果是合法的数值表达则返回该数字,否则返回0示例1输入复制+21474836471a33输出复制21474836470class Solution {public: int Str...

2019-11-05 23:01:04 132

原创 【剑指OFFER】不用加减乘除做加法

题目描述写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。class Solution {public: int Add(int num1, int num2) { while(num2!=0){ int sum = num1 ^ num2 ; int tmp = (num1&...

2019-11-05 22:31:59 76

原创 【剑指OFFER】求1+2+3+...+n

题目描述求1+2+3+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。方法1:class Solution {public: int Sum_Solution(int n) { bool a[n][n+1]; return sizeof(a)>>1; }...

2019-11-04 22:25:29 84

原创 【剑指OFFER】孩子们的游戏

题目描述每年六一儿童节,牛客都会准备一些小礼物去看望孤儿院的小朋友,今年亦是如此。HF作为牛客的资深元老,自然也准备了一些小游戏。其中,有个游戏是这样的:首先,让小朋友们围成一个大圈。然后,他随机指定一个数m,让编号为0的小朋友开始报数。每次喊到m-1的那个小朋友要出列唱首歌,然后可以在礼品箱中任意的挑选礼物,并且不再回到圈中,从他的下一个小朋友开始,继续0…m-1报数…这样下去…直到剩下最后一...

2019-11-04 22:08:55 112

原创 【剑指OFFER】扑克牌顺子

题目描述LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张_)…他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子…LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K为13。上面的5张...

2019-10-28 09:35:10 202

原创 【剑指OFFER】翻转单词顺序列

题目描述LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张_)…他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定去买体育彩票,嘿嘿!!“红心A,黑桃3,小王,大王,方片5”,“Oh My God!”不是顺子…LL不高兴了,他想了想,决定大\小 王可以看成任何数字,并且A看作1,J为11,Q为12,K为13。上面的5张...

2019-10-25 20:28:23 116

原创 【剑指OFFER】翻转单词顺序列

题目描述牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“student. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a student.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么?class Soluti...

2019-10-24 20:57:36 104

原创 【剑指OFFER】坐旋转字符串

题目描述汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!class Solution {public: string LeftRotateStr...

2019-10-24 20:56:33 104

原创 【剑指OFFER】和为S的两个数字

题目描述输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。输出描述:对应每个测试案例,输出两个数,小的先输出。class Solution {public: vector<int> FindNumbersWithSum(vector<int> array,int sum) { ...

2019-10-24 09:36:39 97

原创 【剑指OFFER】和为S的连续正数序列

题目描述小明很喜欢数学,有一天他在做数学作业时,要求计算出9~16的和,他马上就写出了正确答案是100。但是他并不满足于此,他在想究竟有多少种连续的正数序列的和为100(至少包括两个数)。没多久,他就得到另一组连续正数和为100的序列:18,19,20,21,22。现在把问题交给你,你能不能也很快的找出所有和为S的连续正数序列? Good Luck!输出描述:输出所有和为S的连续正数序列。序...

2019-10-23 13:41:08 111

原创 【剑指OFFER】数组只出现一次的数字。

题目描述一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。题目分析:如果只有一个数字出现一次,那么全部异或就可以得到答案。现在题目有两个数字出现一次,全部异或的结果就是这两个数字异或的值。根据这个值的某一位字节为0或者1,可以把数组分成2份,每一份有一个只出现一次的数字。分别异或的结果就是答案。class Solution {public: ...

2019-10-22 10:40:43 71

原创 【剑指OFFER】平衡二叉树

题目描述输入一棵二叉树,判断该二叉树是否是平衡二叉树。方法1:class Solution {public: bool IsBalanced_Solution(TreeNode* pRoot) { if(!pRoot) return true; return abs(maxDeepth(pRoot->left)-maxDeepth(pRoot-...

2019-10-18 21:06:40 99

原创 【剑指OFFER】二叉树的深度

题目描述输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。递归:class Solution {public: int TreeDepth(TreeNode* pRoot) { return pRoot==NULL?0: max(TreeDepth(pRoot->left)+1,Tr...

2019-10-10 12:35:25 72

原创 【剑指OFFER】数字在排序数组中出现的次数

题目描述统计一个数字在排序数组中出现的次数。class Solution {public: int GetNumberOfK(vector<int> data ,int k) { int right = GetLastNumK(data,k); //int right = GetLastNumK2(data,k,0,data.size()-...

2019-10-08 00:54:47 78

原创 【剑指OFFER】两个链表的第一个公共结点。

题目描述输入两个链表,找出它们的第一个公共结点。class Solution {public: ListNode* FindFirstCommonNode( ListNode* pHead1, ListNode* pHead2) { int len1=findLength(pHead1); int len2=findLength(pHead2); ...

2019-10-05 23:28:41 65

原创 【剑指OFFER】数组中的逆序对(归并排序)

题目描述在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P%1000000007输入描述:题目保证输入的数组中没有的相同的数字数据范围:对于%50的数据,size<=10^4对于%75的数据,size<=10^5对于%100的数据,size...

2019-09-18 13:44:07 150

原创 【剑指OFFER】第一个只出现一次的字符

题目描述在一个字符串(0<=字符串长度<=10000,全部由字母组成)中找到第一个只出现一次的字符,并返回它的位置, 如果没有则返回 -1(需要区分大小写).class Solution {public: int FirstNotRepeatingChar(string str) { map<char,int> mp; for(...

2019-09-11 19:45:04 72

原创 【剑指OFFER】丑数(求质数)

题目描述把只包含质因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含质因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。class Solution {public: int GetUglyNumber_Solution(int index) { vector<int> vec(inde...

2019-09-11 14:14:39 155

原创 【剑指OFFER】把数组排成最小的数

题目描述输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。class Solution {public: static bool cmp( string s1, string s2){ return s1+s2<s2+s1; ...

2019-09-10 20:46:39 72

原创 【CodeForce】1214C Bad Sequence

题意:最多允许移动一个字符的位置,判断是不是一个合法的括号序列。#include <iostream>#include <queue>#include <functional>#include <cstring>using namespace std;using namespace std;const int N = 200001;...

2019-09-05 14:30:12 333

原创 【CodeForce】1214B Badges

题目链接:http://codeforces.com/problemset/problem/1214/B题意:b个男生和g个女生去参加运动会,只有n个人可以参加,男生需要红色徽章,女生需要蓝色徽章,求要准备多少种徽章方案,即n个人中,男女生有多少种组合。直接暴力枚举就行#include <iostream>#include <queue>#include <...

2019-09-05 13:58:57 165

原创 【CodeForce】1214A Optimal Currency Exchange

题目链接:http://codeforces.com/problemset/problem/1214/A题意:有n个卢布,要换成美元和欧元,使手上剩余的卢克最少。一美元价值d卢布,一欧元价值e卢克。分析:欧元的面值最小为5,其实的都少5的倍数,美元最小面值为1。其实这里就可以转换成2个物品的无限背包问题,然而n值较大,背包算法不合适。只有2个物品,暴力枚举即可。解法1:动态规划,无法通过。...

2019-09-05 11:23:59 296 1

原创 【剑指OFFER】整数中1出现的次数

题目描述求出1-13的整数中1出现的次数,并算出100-1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1、10、11、12、13因此共出现6次,但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数)。解法1:直接计算,没什么好说的 int calNum1(int ...

2019-09-04 17:04:59 115

原创 【剑指Offer】最小的K个数

题目描述输入n个整数,找出其中最小的K个数。例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,。方法1:堆排序class Solution {public: void HeapAdjust(vector<int> &input,int s,int n){ int l=s*2+1; while(l...

2019-08-29 20:07:55 87

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

题目描述数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。解法1:使用map,时间复杂度O(n);class Solution {public: int MoreThanHalfNum_Solution(vector<...

2019-08-23 20:49:56 78

原创 【剑指OFFER】字符串的排列

题目描述输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。输入描述:输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。class Solution {public: vector<string> ans; vector...

2019-08-22 17:00:14 71

原创 【剑指OFFER】二叉搜索树与双向链表

题目描述输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向。class Solution {public: void convertLink(TreeNode* cur,TreeNode*& pre) { if(cur==NULL)return; convertLink(c...

2019-08-20 20:31:03 96

原创 【剑指OFFER】复杂链表的复制

题目描述输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head。(注意,输出结果中请不要返回参数中的节点引用,否则判题程序会直接返回空)class Solution {public: RandomListNode* Clone(RandomListNode* pHead) { ...

2019-08-16 10:12:06 62

原创 【剑指OFFER】二叉树中结点值的和为输入整数的所有路径

题目描述输入一颗二叉树的根节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。(注意: 在返回值的list中,数组长度大的数组靠前)class Solution {public: vector<vector<int> >ans; vector<int> tmp;...

2019-08-14 21:22:06 156

软件工程毕业课程设计

某重点大学 软件工程毕业课程设计,还是有一定参考价值

2014-09-18

SQL基础教程

非常好的一个SQL基础教程,我自己看了 觉得比较有用

2014-09-18

组成原理课程设计

重点院校的计算机组成原理课程设计报告,比较详细

2014-09-18

C语言经典小程序

上百个C语言的经典题和代码,十分适合初学C语言的同学

2011-12-07

空空如也

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

TA关注的人

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