• 牛客错题笔记


    1、以下哪个选项一定可以将flag的第二个bit置0

    • flag&=~2
    • flag|=2
    • flag^=2
    • flag>>=2

    |:只要有一个1即为1

    &:同为1时才为1

    ^:两个数相同时为1,不同为0

    ~:取反

    >>:右移

    2转化为二进制:0010,第二位为1

    分析选择A

    2、请声明一个指针,其所指向的内存地址不能改变,但内存中的值可以被改变。

    • const int const *x = &y;
    • int * const x = &y;
    • const int *x = &y;
    • int const *x = &y;
    • const int * const x = &y;

    const在*前,指针指向空间的值不能修改

    const在*后,指针的指向不能修改

    3、在上下文和头文件正常的情况下,以下C语言指令:

    1. int a[5] = {1,3,5,7,9};
    2. int *p = (int *)(&a+1);
    3. printf("%d,%d",*(a+1),*(p-1));

    运行结果是什么?

    数组名只有在&与sizeof的后面,表示的是数组本身,指针p指向的是9之后

    4、 以下程序的输出结果是:

    1. #include <iostream>
    2. using namespace std;
    3. void func(char **m){
    4. ++m;
    5. cout<<*m<<endl;
    6. }
    7. int main(){
    8. static char *a[]={"morning", "afternoon", "evening"};
    9. char **p;
    10. p=a;
    11. func(p);
    12. return 0;
    13. }

     m指向的是morning

    向后偏移一个元素大小,即为afternoon

     5、求函数返回值,输入x=9999

    1. int func(int x){
    2. int count = 0;
    3. while (x){
    4. count++;
    5. x = x&(x - 1);//与运算
    6. }
    7. return count;
    8. }

    该函数功能实际上就是求一个数转化为二进制后之中1的个数,所以为8

    6 、下列程序执行后,输出的结果为()

    1. #include <stdio.h>
    2. int cnt = 0;
    3. int fib(int n) {
    4. cnt++;
    5. if (n == 0)
    6. return 1;
    7. else if (n == 1)
    8. return 2;
    9. else
    10. return fib(n - 1) + fib(n - 2);
    11. }
    12. void main() {
    13. fib(8);
    14. printf("%d", cnt);
    15. }
    • 41
    • 67
    • 109
    • 177 

    cnt实际在统计斐波那契数列递归的次数

    F0:1次 

    F1:1次

    F2:F0+F1=3次

    F3:F2+F1=1+1+3=5次

    F4:F3+F2=1+5+3=9次

    F5:F4+F3=1+9+5=15次

    F6:F5+F4=1+15+9=25次

    F7:F6+F5=1+25+15=41次

    F8:F7+F6=1+41+25=67次 

  • 相关阅读:
    【1++的Linux】之文件(二)
    WebStorm安装教程
    通过线程池方式改造Stream.parallel()并行流
    神经网络模型训练简记(一)
    网络工程师的爬虫技术之路:跨界电商与游戏领域的探索
    Java零基础-正则表达式
    Android中使用Java计算指定日期、时间戳等方法的合集
    力扣每日一题 ---- 2918. 数组的最小相等和
    开源文档编辑器ONLYOFFICE最新版7.5发布
    LVS-RD和keepalived集群服务
  • 原文地址:https://blog.csdn.net/weixin_53032617/article/details/126799618