《剑指Offer》题六十一~题六十八
六十一、扑克牌中的顺子
题目:从扑克牌中随机抽5张牌,判断是不是一个顺子,即这5张牌是不是连续的。2~10为数字本身,A为1,J为11,Q为12,K为13,而大、小王可以看成任意数字。
六十二、圆圈中最后剩下的数字
题目:0, 1, …, n-1这n个数字排成一个圆圈,从数字0开始,每次从这个圆圈里删除第m个数字。求出这个圆圈里剩下的最后一个数字。
六十三、股票的最大利润
题目:假设把某股票的价格按照时间先后顺序存储在数组中,请问买卖该股票一次可能获得的最大利润是多少?例如,一只股票在某些时间节点的价格为{9, 11, 8, 5, 7, 12, 16, 14}。如果我们能在价格为5的时候买入并在价格为16时卖出,则能收获最大的利润11。
六十四、求1+2+…+n
题目:求1+2+…+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。
提示:这道题本身没什么实际意义,但不少面试官认为这是一道考查应聘者发散思维能力的题目。
分析:循环只是让相同的代码重复执行n遍而已,我们可以不用for和while来达到这个效果。比如我们先定义一个类型,接着创建n个该类型的实例,那么这个类型的构造函数将会被调用n次。
利用构造函数求解:
class Temp {
public:
Temp()
{
N++;
SUM += N;
}
static void reset()
{
N = 0;
SUM = 0;
}
static unsigned int getSum()
{
return SUM;
} private:
static unsigned int N;
static unsigned int SUM;
}; unsigned int sum_one_to_n(unsigned int n)
{
Temp::reset(); Temp *arr = new Temp[n];
delete []arr;
arr = nullptr; return Temp::getSum;
}
六十五、不用加减乘除做加法
题目:写一个函数,求两个整数之和,要求在函数体内不得使用“+”、“-”、“×”、“÷”四则运算符号。
提示:对数字做运算,除四则运算之外,也就只剩下位运算了。
分析:二进制加法和十进制加法的过程一样,都是①各位相加不进位,②记下进位,③把前两步的结果相加。对于二进制加法来说,第一步的结果和异或的结果是一样的,第二步的结果等价于两个数先做位与运算,然后再向左移动一位,第三步把前两个步骤的结果相加,过程依然是重复前面两步。
位运算解法:
int add_with_bit(int num1, int num2)
{
int sum = 0;
int carry = 0;
do {
// 第一步
sum = num1 ^ num2;
// 第二步
carry = (num1 & num2) << 1;
// 第三步
num1 = sum;
num2 = carry;
} while(num2 != 0); return sum;
}
六十六、构建乘积数组
题目:给定一个数组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]。不能使用除法。
六十七、把字符串转换成整数
题目:写一个函数StrToInt,实现把字符串转换成整数这个功能。要求不能使用atoi或者其他类似的库函数。
没有考虑非法输入的解法:
int StrToInt(char *pStr)
{
if(pStr == nullptr) return -1;
int num = 0;
char *pCur = pStr;
while(*pCur != '\0') {
num = num * 10 + *pCur - '0';
pCur++;
}
return num;
}
分析:上述解法虽简洁,但也遗漏了许多检错点。比如,①当输入的字符串为空串或输入的字符串是"0"时,该函数都返回0;②'+'和'-'字符是合法的输入符,而其他字符是非法字符;③当输入的字符串只含"+"和"-"时,虽然它们是合法字符,但该字符串却不合法。
完善后的代码:
int StrToInt(char *pStr)
{
error = 0;
if(pStr == nullptr) {
return 0;
error = 1;
}
if(*pStr == '\0') {
return 0;
error = 2;
}
int plus = 0;
int minus = 0;
if(*pStr == '+') {
plus = 1;
pStr++;
}
if(*pStr == '-') {
minus = 1;
pStr++;
}
int num = 0;
while(*pStr != '\0') {
if(*pStr > '9' || *pStr < '0') {
return 0;
error = 3;
}
num = num * 10 + *pStr - '0';
pStr++;
}
if(minus == 1) {
num *= -1;
}
if(num == 0)
error = 4;
return num;
}
六十八、树中两个节点的最低公共祖先
题目:输入两个树节点,求它们的最低公共祖先。(1)若该树是二叉搜索树;(2)若该树只是普通的树,但树中的节点中有指向父节点的指针;(3)若该树只是普通的树,而且树中的节点没有指向父节点的指针。
《剑指Offer》题六十一~题六十八的更多相关文章
- 《剑指offer》第二十一题(调整数组顺序使奇数位于偶数前面)
// 面试题21:调整数组顺序使奇数位于偶数前面 // 题目:输入一个整数数组,实现一个函数来调整该数组中数字的顺序,使得所有 // 奇数位于数组的前半部分,所有偶数位于数组的后半部分. #inclu ...
- 《剑指offer》第十一题(旋转数组的最小数字)
// 面试题:旋转数组的最小数字 // 题目:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. // 输入一个递增排序的数组的一个旋转,输出旋转数组的最小元素.例如数组 // {3, ...
- 剑指Offer(二十一):栈的压入、弹出序列
剑指Offer(二十一):栈的压入.弹出序列 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net/b ...
- 剑指Offer(三十一):整数中1出现的次数(从1到n整数中1出现的次数)
剑指Offer(三十一):整数中1出现的次数(从1到n整数中1出现的次数) 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https:// ...
- [持久更新] 剑指offer题目Python做题记录
第一题 题目:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 思路:先快速定位到 ...
- 【剑指Offer】俯视50题之21 - 30题
面试题21包括min函数的栈 面试题22栈的压入.弹出序列 面试题23从上往下打印二叉树 面试题24二叉搜索树的后序遍历序列 面试题25二叉树中和为某一值的路径 面试题26复杂链表的复制 ...
- 《剑指offer》第十三题(机器人的运动范围)
// 面试题:机器人的运动范围 // 题目:地上有一个m行n列的方格.一个机器人从坐标(0, 0)的格子开始移动,它 // 每一次可以向左.右.上.下移动一格,但不能进入行坐标和列坐标的数位之和 // ...
- 《剑指Offer》第1题(Java实现):在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
一.题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该 ...
- 《剑指Offer》第20题(Java实现):定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。
一.题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)). 二.思路解析 首先定义一个Integer类型的栈,记为stack,此栈用来完成数据 ...
- 《剑指offer》第二十七题(二叉树的镜像)
// 面试题27:二叉树的镜像 // 题目:请完成一个函数,输入一个二叉树,该函数输出它的镜像. #include <iostream> #include "BinaryTree ...
随机推荐
- CentOS 6.8安装Ceph
机器规划 IP 主机名 角色 10.101.0.1 ceph01 mon admin mds 10.101.0.2 ceph02 ods 10.101.0.3 ceph03 ods 10.101.0. ...
- 使用JDK开发WebServrice案例
使用JDK开发WebServrice案例: 一.开发WebService服务器端 第一步:创建Java工程 ,创建相应的包(服务端)使用JDK开发(1.6以上版本) 第二步:建一个接口WebServi ...
- Java代码注释
单行注释: 选中代码,按下ctrl+/ 一条代码单行注释:选中一条代码按下ctrl+/,则为一条代码单行注释: 多条代码单行注释:选中多条代码按下ctrl+/,则为多条代码单行注释: 取消注释:对已经 ...
- Python学习 :装饰器
装饰器(函数) 装饰器作为一个函数,可以为其他函数在不修改原函数代码的前提下添加新的功能 装饰器的返回值是一个函数对象.它经常用于有切面需求的场景,比如:插入日志.性能测试.事务处理.缓存.权限校验等 ...
- GDB简单使用
GDB简单使用 更多请参考:https://www.cnblogs.com/HKUI/p/8955443.html https://www.cnblogs.com/skyofbitbit/p/3672 ...
- ISAP学习笔记
学完了ISAP,感觉心情舒畅,毕竟ISAP比Dinic好一点. 说到底ISAP其实是Dinic(不熟悉Dinic的人去我的博客找猴子课堂----最大流与最小割(看看思想),已经置顶)优化版,熟悉的人知 ...
- tkinter的入门,估计也只能站门口
from tkinter import * import tkinter.messagebox as messagebox #创建一个继承frame的类,是所有小部件(widget的容器) #widg ...
- MySQL高级第五章——主从复制
一.复制的基本原理 slave会从master读取binlog(二进制日志文件)进行数据同步 步骤: 详细操作步骤请参见:http://www.cnblogs.com/luckcs/articles/ ...
- 算法-PHP实现八大算法
八大算法原理详解 交换函数:注意要按引用传递,否则无法真正交换两个数的值 function exchange(&$a, &$b){ $temp = $a; $a = $b; $b = ...
- 北京Uber优步司机奖励政策(3月14日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...