【算法竞赛】运算符秒杀大厂面试题

简介: 【算法竞赛】运算符秒杀大厂面试题

本期是一些大厂的面试题,都是关于运算符的,不多,但是涵盖的知识不少,希望大家有所收获!


下面代码的功能是什么呢?


平均数


#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int half(int a, int b)
{
  return (a & b) + ((a ^ b) >> 1);
}
int main()
{
  int a, b;
  scanf("%d%d", &a, &b);
  printf("%d",half(a, b));
  return 0;
}


efe34e88ea5278d573a77586a8610608_628140e8dfc54bff8eb5470ee569c238.png


答案是求两数的平均数。


这道题用笨方法的话就是转化成二进制然后按位与,但是这样的做法显然不是面试官所期待的,如果熟悉你熟悉操作符,那你就会知道。


x&y是取相同的位与,这个操作的结果是x和y相同位和的一半。


而x^y是不同位,右移一位就相当于除以二。


所以这个函数的功能就是求两个数的平均数。


看下面的例题前,先明白一个概念。


1. 二进制位异或运算就相当于对应位相加,不考虑进位

例如: 1 ^ 1 = 0 ---> 1 + 1 = 0 (进一位)

           1 ^ 0 = 1 ---> 1 + 0 = 1 (当前位值为1)

           0 ^ 0 = 0 ---> 0 + 0 = 0 (当前位值为0)


2. 二进制位与运算相当于对应位相加之后的进位

例如: 1 & 1 = 1 ---> 1 + 1 = 0 (进一位)

           1 & 0 = 0 ---> 1 + 0 = 1 (不进位)

           0 & 0 = 0 ---> 0 + 0 = 0 (不进位)


3. 两数相加就等于对应二进制位相加的结果 + 进位的结果

例如:3 + 2 --> 0011 + 0010---> 0011 ^ 0010 + ((0011 & 0010) << 1)

          ---> (0011 ^ 0010) ^ ((0011 & 0010) << 1), 当进位之后的结果为0时,相加结束


趁热打铁,看下面函数的功能。


求和


#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int Add(int a, int b)
{
  if (b == 0)
  {
  return a;//没有进位时完成运算
  }
  int sum, carry;
  sum = a ^ b;//为了完成第一步没有进位的加法运算
  carry = ((a & b) << 1);//完成第二步进位并左移
  return Add(sum, carry);//进行递归,相加
}
int main()
{
  int a, b;
  scanf("%d%d", &a, &b);
  printf("%d",Add(a, b));
  return 0;
}


d0f489ffda23dc4f29308d981a0298ed_ebccb046913147c6aec6c846d8d05e53.png


大家肯定一眼就看出来了,函数的功能是实现两数相加。


判断


再来看一道题目吧!


用一个表达式,判断一个数X是否是2的N次方,不能使用循环语句。


这道题同样是用操作符来解答。


答案是!(X&(X-1))。


2,4,8这样的数转换成二进制是10,100,1000,如果X和X减一运算,答案是0,则X是2的N次方。


总结

 感谢观看,本文到这里就结束了,如果觉得有帮助,请给文章点个赞吧,让更多的人看到。🌹 🌹 🌹


c7083b14aa03db83c69ebf229bfba1e5_f041841653294f6c8a0702ed05b61072.jpeg


 也欢迎你,关注我。👍 👍 👍


 原创不易,还希望各位大佬支持一下,你们的点赞、收藏和留言对我真的很重要!!!💕 💕 💕 最后,本文仍有许多不足之处,欢迎各位认真读完文章的小伙伴们随时私信交流、批评指正!下期再见。🎉


相关文章
|
1月前
|
存储 算法 编译器
米哈游面试算法题:有效的括号
米哈游面试算法题:有效的括号
26 0
|
2月前
|
开发框架 算法 搜索推荐
C# .NET面试系列九:常见的算法
#### 1. 求质数 ```c# // 判断一个数是否为质数的方法 public static bool IsPrime(int number) { if (number < 2) { return false; } for (int i = 2; i <= Math.Sqrt(number); i++) { if (number % i == 0) { return false; } } return true; } class Progr
62 1
|
1月前
|
负载均衡 算法 应用服务中间件
面试题:Nginx有哪些负载均衡算法?Nginx位于七层网络结构中的哪一层?
字节跳动面试题:Nginx有哪些负载均衡算法?Nginx位于七层网络结构中的哪一层?
40 0
|
12天前
|
存储 缓存 算法
面试遇到算法题:实现LRU缓存
V哥的这个实现的关键在于维护一个双向链表,它可以帮助我们快速地访问、更新和删除最近最少使用的节点,同时使用哈希表来提供快速的查找能力。这样,我们就可以在 O(1) 的时间复杂度内完成所有的缓存操作。哈哈干净利索,回答完毕。
|
25天前
|
算法 搜索推荐 Python
数据结构与算法在Python面试中的应用实例
【4月更文挑战第13天】本文聚焦Python面试中的数据结构与算法问题,包括排序算法、链表操作和树图遍历。重点讨论了快速排序、链表反转和二叉树前序遍历的实现,并指出理解算法原理、处理边界条件及递归操作是避免错误的关键。通过实例代码和技巧分享,帮助面试者提升面试表现。
13 0
|
25天前
|
设计模式 算法 Java
如何在面试中应对编程与算法面试?
面试中,编程能力至关重要,主要分为三个层次:初级关注基本功,如语法、原理和常见问题解决;高级涉及数据结构与算法,基础算法如排序对中小厂重要,大厂则需深入数据结构;资深专家层次需精通设计模式,以保证代码的扩展性和维护性。提升编程技能可采用PDCA循环学习法,从计划到执行、检查、行动不断迭代。通过实践项目如开发后端系统、测试框架来检验学习成果,并逐步学习算法和设计模式。坚持不懈的努力和重构将助你成为技术专家。记住,超越大多数人的关键在于持续学习和专注深耕。
7 0
如何在面试中应对编程与算法面试?
|
2月前
|
算法
覃超老师 算法面试通关40讲
无论是阿里巴巴、腾讯、百度这些国内一线互联网企业,还是 Google、Facebook、Airbnb 等硅谷知名互联网公司,在招聘工程师的过程中,对算法和数据结构能力的考察都是重中之重。本课程以帮助求职者在短时间内掌握面试中最常见的算法与数据结构相关知识点,学会面试中高频算法题目的分析思路,同时给大家从面试官的角度来分析算法题的解答技巧,从而更有效地提升求职者的面试通过率。
16 3
覃超老师 算法面试通关40讲
|
2月前
|
存储 算法
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
【数据结构与算法】【腾讯阿里链表面试题】算法题--链表易懂版讲解
|
2月前
|
存储 机器学习/深度学习 算法
python常用算法,新手必会,面试必出
python常用算法,新手必会,面试必出
38 0
|
2月前
|
存储 算法 Java
【数据结构与算法】2、链表(简单模拟 Java 中的 LinkedList 集合,反转链表面试题)
【数据结构与算法】2、链表(简单模拟 Java 中的 LinkedList 集合,反转链表面试题)
43 0