【C刷题】day5

这篇具有很好参考价值的文章主要介绍了【C刷题】day5。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、选择题
1、如下程序的功能是( )
#include <stdio.h>
int main()
{
   char ch[80] = "123abcdEFG*&";
   int j;
   puts(ch);
   for(j = 0; ch[j] != '\0'; j++)
   if(ch[j] >= 'A' && ch[j] <= 'Z')
   ch[j] = ch[j] + 'e' - 'E';
   puts(ch);

   return 0;
}

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、对于代码段,下面描述正确的是( )
t=0;
while(printf("*"))
{
  t++;
  if (t<3)
    break;
}

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

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

【答案】:

B

【解析】:

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

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

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


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

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: 修改外层循环条件例如

for( int i = 0 ; i < MAX1 ; i ++ )
{
   for( int j = 0 ; j < MAX2 ; j ++ )
  {
      if( condition )
      {
         i = MAX1;
         break;
      }
   }
}

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


for( ; symbol != 1 && condition2 ; )
{
   for( ; symbol != 1 && condition3 ; )
   {
       if( condition1 )
          symbol = 1 ;
   }
}

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

for( ; condition2 ; )
{
   for( ; condition3 ; )
   {
     if( condition1 )
         symbol = 1 ;
   } 
  if(symbol == 1 )
      break ;
}

【答案】:

ABCD

【解析】:

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

跳出多层循环的方法:

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

goto end;

....

end:statement;

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

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

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


二、编程题

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

【C刷题】day5,【C】每日一练,c语言,算法,数据结构

【参考答案】: 

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

注意:

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

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

int GetNumberOfK(int* nums, int numsLen, int k ) {
    int rightbound = 0;
    int leftbound = 0;
    int left = 0;
    int right = numsLen - 1;
    int mid = 0;
 
    //k不在nums的范围内
    if (nums[0] > k || nums[numsLen - 1] < k)
        return 0;
    //k在nums的范围内
    else {
        //找下界
        while (left < right) {
            //这里的mid要+1,不然当nums为【3,3,3,3】无法跳出循环
            mid = (left + right) / 2+1;
            if (nums[mid] > k) {
                right = mid - 1;
            } else {
                left = mid;
            }
        }
        rightbound = right;
 
        //left和right恢复原值
        left = 0;
        right = numsLen - 1;
 
        //找上界
        while (left < right) {
            mid = (left + right) / 2;
            if (nums[mid] >= k) {
                right = mid;
            } else {
                left = mid + 1;
            }
        }
        leftbound = left;
 
        return rightbound - leftbound + 1;
    }
 
}

2. 整数转换

【C刷题】day5,【C】每日一练,c语言,算法,数据结构

 【参考答案】: 

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

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

int convertInteger(int A, int B)
{
    int count=0;
    for(int i=0;i<32;i++)
    {
        if(((A>>i)&1)!=((B>>i)&1))
        {
            count++;
        }
    }
    return count;
}

方法二:先A^B(如果对应位上数值相同则为1,不同则为0),如果再取出C的每一位上的二进制数,如果是1就count++文章来源地址https://www.toymoban.com/news/detail-721642.html

int convertInteger(int A, int B)
{
    int count=0;
    int C=A^B;
    for(int i=0;i<32;i++)
    {
        if(((C>>i)&1)==1)
        {
            count++;
        }
    }
    return count;
}

到了这里,关于【C刷题】day5的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • C语言每日一练------------Day(7)

    本专栏为c语言练习专栏,适合刚刚学完c语言的初学者。本专栏每天会不定时更新,通过每天练习,进一步对c语言的重难点知识进行更深入的学习。 今日练习题: 两个数组的交集     双指针 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C语言天天练 🚚代码仓库:

    2024年02月10日
    浏览(43)
  • C语言每日一练--------Day(11)

    本专栏为c语言练习专栏,适合刚刚学完c语言的初学者。本专栏每天会不定时更新,通过每天练习,进一步对c语言的重难点知识进行更深入的学习。 今日练习题: 找到数组中消失的数字 哈希表 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C语言天天练 🚚代码仓库:

    2024年02月10日
    浏览(45)
  • C语言每日一练--Day(15)

    本专栏为c语言练习专栏,适合刚刚学完c语言的初学者。本专栏每天会不定时更新,通过每天练习,进一步对c语言的重难点知识进行更深入的学习。 今日练习题: 珠玑妙算 两数之和 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C语言天天练 🚚代码仓库:小小unicorn的

    2024年02月10日
    浏览(42)
  • C语言每日一练------(Day3)

    本专栏为c语言练习专栏,适合刚刚学完c语言的初学者。本专栏每天会不定时更新,通过每天练习,进一步对c语言的重难点知识进行更深入的学习。 今天练习题的: 尼科彻斯定理 等差数列 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C语言天天练 🚚代码仓库:小小

    2024年02月10日
    浏览(40)
  • C语言:选择+编程(每日一练Day14)

    目录 选择题: 题一: 题二: 题三: 题四: 题五: 编程题: 题一:珠玑妙算 思路一: 题二:两数之和 思路一: 本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵! 感谢大佬们的一键三连! 感谢大佬们的一键三连

    2024年02月09日
    浏览(60)
  • C语言:选择+编程(每日一练Day11)

    目录 选择题: 题一: 题二: 题三: 题四: 题五: 编程题: 题一:最大连续1的个数 思路一: 题二:完全数计算  思路二: 本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵! 感谢大佬们的一键三连! 感谢大佬们

    2024年02月09日
    浏览(48)
  • C语言:选择+编程(每日一练Day12)

    目录 选择题: 题一: 题二: 题三: 题四: 题五: 编程题: 题一:数组颠倒 思路一: 题二:单词倒排 思路一: 思路二: 本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵! 感谢大佬们的一键三连! 感谢大佬们的

    2024年02月09日
    浏览(49)
  • C语言:选择+编程(每日一练Day16)

    目录 选择题: 题一: 题二: 题三: 题四: 题五: 编程题: 题一:数对 思路一: 题二:截取字符串 思路一: 本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵! 感谢大佬们的一键三连! 感谢大佬们的一键三连!

    2024年02月09日
    浏览(70)
  • C语言:选择+编程(每日一练Day13)

    目录 选择题: 题一: 题二: 题三: 题四: 题五: 编程题: 题一:统计每个月兔子的总数 思路一: 题二:数列的和 思路一: 本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵! 感谢大佬们的一键三连! 感谢大佬

    2024年02月08日
    浏览(49)
  • C语言:选择+编程(每日一练Day15)

    目录 选择题: 题一: 题二: 题三: 题四: 题五: 编程题: 题一:寻找奇数 思路一: 题二:寻找峰值 思路一: 本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵! 感谢大佬们的一键三连! 感谢大佬们的一键三连

    2024年02月10日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包