• 【C刷题】day5


    一、选择题
    1、如下程序的功能是( )
    1. #include
    2. int main()
    3. {
    4. char ch[80] = "123abcdEFG*&";
    5. int j;
    6. puts(ch);
    7. for(j = 0; ch[j] != '\0'; j++)
    8. if(ch[j] >= 'A' && ch[j] <= 'Z')
    9. ch[j] = ch[j] + 'e' - 'E';
    10. puts(ch);
    11. return 0;
    12. }

    A: 测字符数组ch的长度

    B: 将数字字符串ch转换成十进制数

    C: 将字符数组ch中的小写字母转换成大写

    D: 将字符数组ch中的大写字母转换成小写

    【答案】:

    D

    【解析】:

    考点:大小写转换(ASCII值)一个字母对应的小写比大写的ASCII码值大32

    'e'和'E'之间的ASCII码值相差32(ch[j]+'e'-'E'相当于ch[j]+32)。一个字母从大写转化为小写就是在它自身上+32,小写转大写则是-32


    2、对于代码段,下面描述正确的是( )
    1. t=0;
    2. while(printf("*"))
    3. {
    4. t++;
    5. if (t<3)
    6. break;
    7. }

     A: 其中循环控制表达式与0等价 B: 其中循环控制表达式与'0'等价

    C: 其中循环控制表达式是不合法的 D: 以上说法都不对

    【答案】:

    B

    【解析】:

    考点:‘0’表示真,并不是0

    printf(“*”)函数调用的返回值是字符串中字符的个数,即为1。

    所以while后面的条件恒为真,所以循环控制表达式与'0'是等价的(字符'0'不是0)


    3、以下程序运行时,若输入 1abcedf2df<回车> 输出结果是( )
    1. #include
    2. int main()
    3. {
    4. char ch;
    5. while ((ch = getchar()) != '\n')
    6. {
    7. if (ch % 2 != 0 && (ch >= 'a' && ch <= 'z'))
    8. ch = ch - 'a' + 'A';
    9. putchar(ch);
    10. }
    11. printf("\n");
    12. return 0;
    13. }

    A: 1abcedf2df B: 1ABCEDF2DF C: 1AbCEdf2df D: 1aBceDF2DF

    【答案】:

    C

    【解析】:

    考点:大小写转换(ASCII值)'a'的ACSII值为97,'A'的ASCII值为65

    程序首先考虑ch的ASCII码值是不是奇数,再看是不是小写字母,同时满足时被改为大写字母


    4、下列条件语句中,功能与其他语句不同的是( )

    A: if(a) printf("%d\n",x); else printf("%d\n",y); B: if(a==0) printf("%d\n",y); else printf("%d\n",x);

    C: if (a!=0) printf("%d\n",x); else printf("%d\n",y); D: if(a==0) printf("%d\n",x); else printf("%d\n",y);

    【答案】:

    D

    【解析】:

    考点:if语句中a省略相当于a!=0

    D选项与众不同,其他都是a==0时输出y,a!=0时输出x


    5、我们知道C语言的 break 语句只能跳出离它最近的一层循环,可是有时候我们需要跳出多层循环,下列跳出多层循环的做法正确的是【多选】( )

    A: 将程序写成函数用return结束函数,便可跳出循环

    B: 修改外层循环条件例如

    1. for( int i = 0 ; i < MAX1 ; i ++ )
    2. {
    3. for( int j = 0 ; j < MAX2 ; j ++ )
    4. {
    5. if( condition )
    6. {
    7. i = MAX1;
    8. break;
    9. }
    10. }
    11. }

    C: 在外层循环设置判断条件例如

    1. for( ; symbol != 1 && condition2 ; )
    2. {
    3. for( ; symbol != 1 && condition3 ; )
    4. {
    5. if( condition1 )
    6. symbol = 1 ;
    7. }
    8. }

    D: 在外层循环后面加入break例如

    1. for( ; condition2 ; )
    2. {
    3. for( ; condition3 ; )
    4. {
    5. if( condition1 )
    6. symbol = 1 ;
    7. }
    8. if(symbol == 1 )
    9. break ;
    10. }

    【答案】:

    ABCD

    【解析】:

    考点:跳出多层循环的方法

    跳出多层循环的方法:

    (1)goto语句(把控制无条件转移到同一函数内的被标记的语句)

    goto end;
    

    ....

    end:statement;

    (2) 程序写成函数用return结束函数

    (3)设置条件使外层循环条件不成立,再+break跳出内层循环

    (4)在内层循环让flag为1,在跳出内层循环进入外层循环时如果flag==1,就break跳出


    二、编程题

    1.数字在升序数组中出现的次数

    【参考答案】: 

    考察二分查找:需要找出等于k的上界leftbound和下界rightbound

    注意:

    (1)同时需要考虑特殊情况:k不在nums的范围内,这个时候计算上下界没有意义

    (2)在找下界时,其中一个mid要+1,不然当nums为【3,3,3,3】无法跳出循环

    1. int GetNumberOfK(int* nums, int numsLen, int k ) {
    2. int rightbound = 0;
    3. int leftbound = 0;
    4. int left = 0;
    5. int right = numsLen - 1;
    6. int mid = 0;
    7. //k不在nums的范围内
    8. if (nums[0] > k || nums[numsLen - 1] < k)
    9. return 0;
    10. //k在nums的范围内
    11. else {
    12. //找下界
    13. while (left < right) {
    14. //这里的mid要+1,不然当nums为【3,3,3,3】无法跳出循环
    15. mid = (left + right) / 2+1;
    16. if (nums[mid] > k) {
    17. right = mid - 1;
    18. } else {
    19. left = mid;
    20. }
    21. }
    22. rightbound = right;
    23. //left和right恢复原值
    24. left = 0;
    25. right = numsLen - 1;
    26. //找上界
    27. while (left < right) {
    28. mid = (left + right) / 2;
    29. if (nums[mid] >= k) {
    30. right = mid;
    31. } else {
    32. left = mid + 1;
    33. }
    34. }
    35. leftbound = left;
    36. return rightbound - leftbound + 1;
    37. }
    38. }

    2. 整数转换

     【参考答案】: 

    方法一:取出A和B每一位二进制数(&1),不一样就count++

    注意这里((A>>i)&1)外层括号要加,因为!=的优先级高于&

    1. int convertInteger(int A, int B)
    2. {
    3. int count=0;
    4. for(int i=0;i<32;i++)
    5. {
    6. if(((A>>i)&1)!=((B>>i)&1))
    7. {
    8. count++;
    9. }
    10. }
    11. return count;
    12. }

    方法二:先A^B(如果对应位上数值相同则为1,不同则为0),如果再取出C的每一位上的二进制数,如果是1就count++

    1. int convertInteger(int A, int B)
    2. {
    3. int count=0;
    4. int C=A^B;
    5. for(int i=0;i<32;i++)
    6. {
    7. if(((C>>i)&1)==1)
    8. {
    9. count++;
    10. }
    11. }
    12. return count;
    13. }

  • 相关阅读:
    Spring的BeanDefinition的作用和使用方法
    相机的白平衡
    吾爱第三课-修改版权和资源
    分布式服务器架构的优点有哪些?
    vim 中批量添加注释
    STM32出现 Invalid Rom Table 芯片锁死解决方案
    泛型通配符,上下限 ,生活案例介绍
    因mapjoin加载内存溢出而导致return code 3
    【Day-35慢就是快】代码随想录-二叉树-二叉搜索树的最近公共祖先
    接口自动化测试实战经验分享,测试用例也能自动生成
  • 原文地址:https://blog.csdn.net/qq_73017178/article/details/133761376