算法-剑指offer
冉冉流年
这个作者很懒,什么都没留下…
展开
-
左旋转字符串(C++)
1.题目描述汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!2.具体算法遍历字符串数组法class Solution {public: string LeftRotateString(string str, int n) { if(原创 2020-08-02 00:48:01 · 229 阅读 · 0 评论 -
数值的整数次方(快速幂的两种方法)
1.题目描述给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。保证base和exponent不同时为02.具体算法- 递归快速幂算法class Solution {public: double Power(double base, int exponent) { if(exponent<0) { base = 1/base; exponent原创 2020-07-30 01:34:29 · 341 阅读 · 0 评论 -
旋转数组的最小数字
1.题目描述把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,4,5}的一个旋转,该数组的最小值为1。NOTE:给出的所有元素都大于0,若数组大小为0,请返回0。2.具体算法class Solution {public: int minNumberInRotateArray(vector<int> rotateArray) { if(rot原创 2020-07-25 01:29:21 · 68 阅读 · 0 评论 -
两个链表的第一个公共结点(C++)
1.题目描述输入两个链表,找出它们的第一个公共结点。2.具体算法/*struct ListNode { int val; struct ListNode *next; ListNode(int x) : val(x), next(NULL) { }};*/class Solution {public: ListNode* FindFirstCommonNode( ListNode* pHead1, ListNode* pHead2) { ListNode*原创 2020-07-22 01:35:34 · 456 阅读 · 0 评论 -
整数中1出现的次数(从1到n中1出现的次数)
1.题目描述求出1-13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1-13中包含1的数字有1、10、11、12、13因此共出现6次,但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数)。2.具体算法class Solution {public: int NumberOf1Between1AndN_Solution(int n) {原创 2020-07-20 01:12:55 · 443 阅读 · 0 评论 -
二进制中1 的个数(C++)
1.题目描述输入一个整数,输出该数32位二进制表示中1的个数。其中负数用补码表示。2.具体算法正确算法class Solution {public: int NumberOf1(int n) { int i = 0; int flag = 1;//定义一个值为1的flag变量 while(flag!=0)//当flag为0时,flag溢出,循环结束 { if((flag&n)!原创 2020-07-19 01:50:13 · 832 阅读 · 0 评论 -
矩形覆盖(C++)
1.题目描述我们可以用21的小矩形横着或者竖着去覆盖更大的矩形。请问用n个21的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?比如n=3时,2*3的矩形块有3种覆盖方法:2.具体算法class Solution {public: int rectCover(int number) { if(number<1)// return 0; else if(number==1||number==2)原创 2020-07-17 00:46:20 · 602 阅读 · 0 评论 -
判断平衡二叉树
1.题目描述输入一棵二叉树,判断该二叉树是否是平衡二叉树。 在这里,我们只需要考虑其平衡性,不需要考虑其是不是排序二叉树2.具体算法class Solution {public: bool IsBalanced_Solution(TreeNode* pRoot) { if(pRoot==NULL) return true;//当根节点为空是,返回true int LeftDepth = Get_Depth(pRoot->left)原创 2020-07-16 12:59:27 · 2905 阅读 · 0 评论 -
用两个栈实现队列
1.题目描述用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。2.具体算法class Solution{public: void push(int node) { stack1.push(node);//将node压入stack1中 } int pop() { int ref;//定义ref为记录出栈的元素 if(!stack2.empty())//记录stack2不为空时的情况原创 2020-07-15 10:56:32 · 74 阅读 · 0 评论 -
连续子序列的最大和
1.题目描述HR偶尔会拿些专业问题来忽悠那些非计算机专业的同学。今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决。但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2,7,-15,1,2,2},连续子向量的最大和为8(从第0个开始,到第3个为止)。给一个数组,返回它的最大连续子序列的和,你会不会被他忽悠住?(子向量的长度至少是1)2.具体算法class Solution {publ原创 2020-07-13 11:15:21 · 216 阅读 · 0 评论 -
构建乘积数组
1.题目描述给定一个数组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];)2.具体算法class Solution {public: vector<int> multiply(const vector<int>原创 2020-07-10 15:31:17 · 104 阅读 · 0 评论 -
求1+2+3+...+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。(C++)
1.具体算法class Solution {public: int Sum_Solution(int n) { int term = n; (term-1)&&(term+=Sum_Solution(term-1)); return term; }};2.算法的总结这个算法的难点是在计算时不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C),所以只能用‘&a原创 2020-07-09 16:57:29 · 268 阅读 · 0 评论 -
一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。(C++)
1.具体算法class Solution {public: int jumpFloorII(int number) { if(number==1) { return 1; } else{ return 2*jumpFloorII(number-1); } }};2.算法推导与总结这个算法的难度在于数学的推导过程,一旦把握了算法的核心数学表达式,所有的原创 2020-07-09 12:05:03 · 1043 阅读 · 0 评论 -
操作给定的二叉树,将其变换为源二叉树的镜像。(C++)
1.具体算法/*struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) { }};*/class Solution {public: void Mirror(TreeNode *pRoot) { if(!pRoot)//首先判断pRoot节点是否为空,如果为空则算法结束原创 2020-07-09 01:54:32 · 347 阅读 · 0 评论 -
输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。(C++)
输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。(C++)1.具体的算法/*struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) { }};*/class Solution {public: int TreeD原创 2020-07-08 17:36:02 · 1090 阅读 · 0 评论 -
写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。
写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。(C++)1.首先给出代码展示:class Solution {public: int Add(int num1, int num2) { while(num2!=0) {&nb原创 2020-07-06 18:22:44 · 1054 阅读 · 0 评论