面试官,求求你不要问我这么简单但又刁难的算法题了

有时候面试官往往会问我们一些简单,但又刁难的问题,主要是看看你对问题的处理思路。如果你没接触过这些问题,可能一时之间还真不知道怎么处理才比较好,这种题更重要的是一种思维的散发吧,今天就来分享几道题面试中遇到的算法题(当然,不是我自己遇到过,是别人遇到过,我挑选出来的)

案例1

题目描述:求1+2+3+...+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)。

我去,求和居然不让用乘除法,也不准我们用循环,如果单独这两个限制的话还好,我们还可以用地递归,例如:

int f(int n){
    if(n == 0){
        return n;
    }else{
        return f(n-1) + n;
    }
}

然后 if, else, case 等各种关键字也不给用,想着那我用三元运算符(A?B:C),然后这种具有判断语句的三元运算符也不给用,我去,这也太刁难了吧(当然,大佬直接秒杀的可以飘过)。

这道题肯定是必须用递归来解决的,而这递归的核心就是需要判断一下递归条件是否结束了,然而题目不准我们使用条件判断语句。那我们该怎么办呢?大家可以散发思维想一下哦。

其实我们可以下面这样的语句来代替 A?B:C 这样具有判断能力的三元运算符

n != 0 && (f(n-1) + n)  != 0;

这个 && 逻辑判断符的作用就是:如果 n != 0 成立的话,那么逻辑判断符后面的判断语句 (f(n-1) + n ) != 0 也会执行,如果 n != 0 不成立的话,那么后面的判断语句 ((f(n-1) + n)) != 0 就不会执行,通过这种方法,就可以达到我们递归结束条件判断的目的了。

这里说明一下,(f(n-1) + n) != 0 这条判断语句是没有任意其他含义的,我们的目的是为了执行 f(n-1)+n,之所以加上个 != 0 的判断,是因为逻辑判断符号 && 只支持 boolean 类型,不支持 int 类型。

最后的代码如下

    public int f(int n) {
        int sum = n;
        boolean t = (n != 0) && (sum += f(n - 1))!= 0;
        return sum;
    }

如果你做过这种类型的题,可能就会觉得很简单了,如果没做过,可能就需要思考一下,不过,往后你就可以直接秒杀了。

案例 2

题目描述:写一个函数,求两个整数之和,要求在函数体内不得使用+、-、*、/四则运算符号。

我去,求和不准加减乘除!面试官,能不能别这么任性,好好的加减乘除居然不给用。

不过我相信大家第一时间都能想到用位运算来解决,可能在大学期间学过电路相关知识的一下就能把代码写出来了,不过有些人也能可能是一个位一个位来处理的。例如我先处理第一个位(这里指的是二进制位哈),看看有没进位,然后处理第二个位,如果第一个位有进位就加到第二个位来,然后处理第三个位.....

如果你是这种方法处理的,那么恭喜你,看完这道题你能有所收获。实际上上面那种解法也可以,只是太复杂了,可能各种判断。其实这道题可以这样解:这里为了方便讲解,我先给出代码,再给出具体的讲解,你看完代码再来看讲解可能更好理解

    public int Add(int num1,int num2) {
        int tmp = 0;
        while(num1 != 0){
            tmp = num1 ^ num2;
            num1 = (num1 & num2) << 1;
            num2 = tmp;
        }
        return num2;
    }

大家想一个问题,如果我们把两个数进行异或,例如num1 = 101, num2 = 001,做异或运算:tmp = num1 ^ num2,结果是 tmp = 100。那么此时得到的结果 tmp 其实就是两个数(num1,num2)各个二进制位上相加,不算进位的结果。而 num1 = (num1 & num2) << 1 的结果就是两个数相加时那些需要进位的二进制位。例如 (101 & 001)<< 1 = 010,那么两个数第一位相加需要进位,我们需要把进的那一位最后加到第二位上去。

好像有点绕,,大家可以动手试一下哈,说白就是 a + b = a ^ b + (a & b) << 1。

代码中,如果 num1 == 0 的话,代表没有进位了,此时就可以退出循环了。

对于很少用位运算的人来说可能有点懵,那么我建议可以多看几遍,然后一遍动手模拟哈。以后遇到这种题就可以直接秒杀了。

案例3

在这里我先声明一下,案例3 也不算一道刁难题,只是我来考考你们而已,大家看到题目之后可以自己想一下哈,看了答案不能打我哈。

题目描述:实现两个整数的相乘,不能使用乘法运算符和循环

各位老哥可以想一下哈。

这道题可能很多人都想到用递归了,好像我说的大部分算法题,都会用到递归,所以说你不懂递归的话,看我的公众号就行了,不懂也得变懂了是不是。代码如下:

int mul(int a, int b){
    if (a == 0 || b == 0)
        return 0;
    if (b == 1)
        return a;
    if (a == 1)
        return b;
    return a + mul(a, b - 1);
}
int mult(int a,int b){
    // 这里我们取 b 的绝对值
    int sum = mul(a, abs(b));
    return (b<0)?(-sum):sum;
}

你是不是这样做的呢?其实,我们还有更好的方法哦,如下

我去,不能使用乘法,又没说不能使用除法,那我用除法来代替乘法就得了,例如 a 乘以 b 就相当于 a 除以 b 分之一。代码如下:

int mult2 (int a,int b){
    return b != 0 ? (int)(a / (1.0 / b) + 0.99 ): 0;
}

这里需要 int 进行转化类型,并且除法可能会导致后面尾数的丢失,所以我补了个 0.99。注意,进行 int 类型转化时,不是四舍五入的哈,二手小于 1 就行当做 0 处理。当然,我这里用的是 Java 语言,其他语言自己看情况处理。

总结

今天的几道题,更多的是一种投机取巧吧,不过看你看到一到陌生的题目时,你会如何处理,点子多不多,这个还是挺重要滴,而多看一些点子,慢慢着你的点子也会变多了。

如果你觉得这篇内容对你挺有启发,为了让更多的人看到这篇文章:不妨

1、点赞,让更多的人也能看到这篇内容(收藏不点赞,都是耍流氓 -_-)

2、关注我和专栏,让我们成为长期关系

3、关注公众号「苦逼的码农」,主要写算法、计算机基础之类的文章,里面已有100多篇原创文章


大部分的数据结构与算法文章被各种公众号转载相信一定能让你有所收获

我也分享了很多视频、书籍的资源,以及开发工具,欢迎各位的关注我的公众号:苦逼的码农,第一时间阅读我的文章。

原文地址:https://www.cnblogs.com/kubidemanong/p/11254542.html

时间: 2024-10-06 13:31:14

面试官,求求你不要问我这么简单但又刁难的算法题了的相关文章

面试官,不要再问我“Java GC垃圾回收机制”了

Java GC垃圾回收几乎是面试必问的JVM问题之一,本篇文章带领大家了解Java GC的底层原理,图文并茂,突破学习及面试瓶颈. 楔子-JVM内存结构补充 在上篇<JVM之内存结构详解>中有些内容我们没有讲,本篇结合垃圾回收机制来一起学习.还记得JVM中堆的结构图吗? 图中展示了堆中三个区域:Eden.From Survivor.To Survivor.从图中可以也可以看到它们的大小比例,准确来说是:8:1:1.为什么要这样设计呢,本篇文章后续会给出解答,还是根据垃圾回收的具体情况来设计的.

如果我是面试官,我想问的一些问题

计算机原理 题目一:请说出”-1 >>> -3”的结果,并说明原理. 提示:本题其实是考察对“移位为负数”这种情况的理解. 答案:若移位值为负数,则实际的移位个数不是后面的直接数字,而是直接数字的最低n位的值.对于int型,n为5:对于long型,n为6.之所以这样,是因为5位最大表示31,移位超过31位对int整数是无效的,long同理. 源码扩展:参见EnumSet的complement方法 ? 原文地址:https://www.cnblogs.com/xiaoxi666/p/105

面试官问现在工资是多少,该怎么回答?

面试,是一个推销自己的过程,先谈能力,后聊价格,顺序不能乱.如何谈薪资,能够做到对候选人最有利,是一门学问,也需要大量的实践.今天,我介绍两个谈薪资的要点给大家,稍加练习,便足以应对大部分的场面. 这个世界,从来都不是公平和客观的,面试也一样.用人单位对候选人的定价,从不看真实价值,往往只根据候选人当前的薪资来定,并且默认最多只会增幅0-20%(没错,不少公司在某些情况下一分钱都不会涨),而候选人对跳槽涨薪的预期一般是30%起.天然的,在谈判开始前,双方对薪资涨幅的预期,就存在巨大鸿沟,如何跨越

面试官求你了,别再问我TCP的三次握手和四次挥手

少点代码,多点头发 本文已经收录至我的GitHub,欢迎大家踊跃star 和 issues. https://github.com/midou-tech/articles 三次握手建立链接,四次挥手断开链接.这个问题算非常经典的问题,也是面试官非常喜欢问的问题. 不夸张的说,龙叔在校招面试的时候每一家公司都问到过关于三次握手和四次挥手相关的问题,相信大家也都差不多被面试官各种怼. 这个问题的重要性,已经意识到.不说废话了,接下来就是听龙叔给你安排的明明白白. 先画个图,看下TCP的建立连接 和

面试官,Java8 JVM内存结构变了,永久代到元空间

在文章<JVM之内存结构详解>中我们描述了Java7以前的JVM内存结构,但在Java8和以后版本中JVM的内存结构慢慢发生了变化.作为面试官如果你还不知道,那么面试过程中是不是有些露怯?作为面试者,如果知晓这些变化,又将成为面试中的亮点. 如果在网络上搜索JVM内存结构,90%的可能会搜到Java7及以前的内存图,本篇文章将会对JVM内存结构再次细化,深入理解Java8之后的内部变化.现在意识到关注公众号"程序新视界"的好处了吧.在这里可以不断的刷新你的知识和认知. JV

【真实面试经历】我和阿里面试官的一次“邂逅”(附问题详解)

本文的内容都是根据读者投稿的真实面试经历改编而来,首次尝试这种风格的文章,花了几天晚上才总算写完,希望对你有帮助. 本文主要涵盖下面的内容: 分布式商城系统:架构图讲解: 消息队列相关:削峰和解耦: Redis 相关:缓存穿透问题的解决: 一些基础问题: 网络相关:1.浏览器输入 URL 发生了什么? 2.TCP 和 UDP 区别? 3.TCP 如何保证传输可靠性? Java 基础:1. 既然有了字节流,为什么还要有字符流? 2.深拷贝 和 浅拷贝有啥区别呢? 下面是正文! 面试开始,坐在我前面

python web为什么要学数据结构与算法面试官为什么总问那几个算法和线性表二叉树

算法是什么? 举个简单的例子 当年刘景生病危刘琦被卷入继位之事 无奈求助于诸葛亮 以上古兵书为由 邀孔明阁楼相谈.... 诸葛亮曾说 那部阵书开篇就是阵法源自于心法 所以古代军师进步也是看兵法 算法也是同理 虽然我们作为web后端开发人员 但是每天所见所闻日子久也就适应了. 但是想要再进一步 两种方法 一 多看高质量代码 二 看算法 我们作为web开发可能算法运用的不是很多 每天也就是写接口调接口和产品经理撕 但是算法最重要的地方是会帮你扩充你的逻辑思维 可能刚看算法的人认为太难了我真学不来 举

面试官问:如何让其他部门重视数据?该怎么答?

本文转自知乎 作者:接地气的陈老师 ----------------------------------------------------- 有同学问:老师,面试官问了我一个这样的问题:"管销售的领导一直不关心数据,而且人家那个部门也一直业绩排名第一,每年的指标都能达标,要怎样让这个领导重视起来呢?"我该怎么回答???? 答:如果不是面试的话,我建议直接放弃这哥们吧.回顾一下我们讲过的业务部门分类(如下图) 天天做用户画像,有多少同学对企业内部数据分析部门的用户进行过画像?哈哈 业务

去百度面试,想知道面试官问哪些问题,看这篇文章

https://mp.weixin.qq.com/s?__biz=MzI0NjM3NjI1NQ==&mid=2247487861&idx=1&sn=34316976cdb0aa2e4df3aa6f1f5cc31d&chksm=e9416325de36ea33200d9944fff37381de11c8d4dc8aeb0cc4b83c6201e56b8ee2bc8c2798cc&mpshare=1&scene=1&srcid=1102ElP5k7MBT