欢迎来到逆袭之路的博客

生三从境界:昨夜西风凋碧树,独上高楼,望尽天涯路。 衣带渐宽终不悔,为伊消得人憔悴。 众里寻他千百度,蓦然回首,那人却在灯火阑珊处。人

剑指offer--3

前言:继续学习剑指offer!!!

面试题10:  

 

这道题相对简单,但要对位运算了解。

位运算大体上只有5种运算,总结如下:

  • 按位与 “&”:

将参与运算的两操作数各对应的二进制位进行与

操作,只有对应的两个二进位均为1时,结果的对

应二进制位才为1,否则为0。

        通常用来将某变量中的某些位清0且同时保留其他位不变。
也可以用来获取某变量中的某一位。
例如,如果需要将int型变量n的低8位全置成0,而其余位
不变,则可以执行:

        n = n & 0xffffff00;

  • 按位或“|”:

按位或运算通常用来将某变量中的某些位置1且保
留其他位不变。
例如,如果需要将int型变量n的低8位全置成1,而
其余位不变,则可以执行:
n |= 0xff;
0xff: 1111 1111

  • 按位异或 “^”
    按位异或运算通常用来将某变量中的某些位取反,
    且保留其他位不变。
    例如,如果需要将int型变量n的低8位取反,而其
    余位不变,则可以执行:
    n ^= 0xff;
    0xff: 1111 1111
  • 左移操作符<<

实际上,左移1位,就等于是乘以2, 左移n位,就等于
是乘以2n。而左移操作比乘法操作快得多。

例如:
9 << 4 相当于9乘16

结果:144

  • 右移操作符 >>

实际上, 右移n位,就相当于左操作数除以2n,并且将
结果往小里取整。

例如:

-25 >> 4 = -2 -25除以16等于负1.几,往小里取整,-2更小
-2 >> 4 = -1
18 >> 4 = 1

复制代码
#include<stdio.h>

int NumberOf1(int n)
{
    int count=0;
    while(n)
    {   
        if(n&1)
            count++;
        n = n >>1;
    }   
    return count;
}

int main()
{
    int n;
    puts("please input your number:");
    scanf("%d",&n);
    printf("numOf1:%d\n",NumberOf1(n));

    return 0;
}
复制代码

面试题11:

注:比较简单,不写了。注意位运算比加减乘除快!!!

面试题12:

 

注:要考虑到n很大的情况.

这个学习要先耽误一段时间,有新需求要做,而且还要交接员工离职留下的任务!!!

 

posted on   逆袭之路666  阅读(178)  评论(0编辑  收藏  举报

编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示