C语言笔试训练【第六天】_dowhile语句一定要有使while为假的表达式吗

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

C语言笔试训练【第三天】

C语言笔试训练【第二天】

C语言笔试训练【第一天】

1、以下叙述中正确的是( )

A: 只能在循环体内和switch语句体内使用break语句
B: 当break出现在循环体中的switch语句体内时,其作用是跳出该switch语句体,并中止循环体的执行
C: continue语句的作用是:在执行完本次循环体中剩余语句后,中止循环
D: 在while语句和do-while语句中无法使用continue语句

break语句通常用在循环语句和switch语句中。当break用于switch语句中时,可使程序跳出switch而执行switch以后的语句;当break语句用于do-while、for、while循环语句中时,可使程序终止循环而执行循环后面的语句,即满足条件时便跳出循环。continue语句的作用是跳过循环体中剩余的语句而强行执行下一次循环。B、C和D三个选项中均有错误。因此 A 选项正确。

2、下列 for 循环的次数为( )

for(int i = 0 ; i || i++ < 5;);

A: 0 B: 5 C: 1 D: 无限

易错:逻辑或运算如果前表达式为真,后表达式不计算**。**第一次循环时i为0,执行i++,第二次循环时i为1,是个真值,不再执行i++,也就死循环了。所以这道题选 D

3、以下描述中正确的是( )

A: 由于do-while循环中循环体语句只能是一条可执行语句,所以循环体内不能使用复合语句

B: do-while循环由do开始,用while结束,在while(表达式)后面不能写分号

C: 在do-while循环体中,不一定要有能使while后面表达式的值变为零(“假”)的操作

D: do-while循环中,根据情况可以省略while

do-while循环中的循环体通常都是复合语句代码块,A错误,while(表达式)后面要写分号,B错误,while不能省,D错误。C中表达式中有 break 也可以退出循环,不一定只能表达式为假,所以选 C

4、设函数 fun 和实参数组的说明是如下形式,则对函数的调用语句中,正确的是( )

void fun(char ch,float x[]);
float a[10];

A:fun(“asd”,a[ ]);         B:fun(‘x’,A)

C:fun(‘68’,2.8);            D:fun(32,a);

A选项数组传参只需要写数组名就行,a[]时错误的,B选项第二个参数写成了大写,错了。C选项第二个参数是浮点数,但是fun函数的第二参数是数组不匹配,fun函数参数x需要传一个数组或者float *指针,只有D选项的形式是正确的。

5、在c语言中,一个函数不写返回值类型,默认的返回类型是()

A :int     B:char    C:void    D:都不是

当函数没写返回类型的时候,默认返回类型为 int 型,所以这道题选  A

6、至少其他数字两倍的最大数

至少是其他数字两倍的最大数icon-default.png?t=N6B9https://leetcode.cn/problems/largest-number-at-least-twice-of-others/

给你一个整数数组 nums ,其中总是存在 唯一的 一个最大整数 。请你找出数组中的最大元素并检查它是否 至少是数组中每个其他数字的两倍 。如果是,则返回 最大元素的下标 ,否则返回 -1 。

  这道题有两种做法,每种解法都要单独考虑只有一个数的情况。

1.拷贝、排序加暴力搜索

int Com(const void*p1,const void* p2)
{
    return *(int*)p1-*(int*)p2;
}
int dominantIndex(int* nums, int numsSize){
    if(numsSize==1)
        return 0;
    int*nums2=(int*)malloc(sizeof(int)*numsSize);
    memcpy(nums2,nums,sizeof(int)*numsSize);
    qsort(nums2,numsSize,sizeof(int),Com);
    if(nums2[numsSize-1]<2*nums2[numsSize-2])
        return -1;
    int i=0;
    for(i=0;i<numsSize;i++)
    {
        if(nums2[numsSize-1]==nums[i])
            break;
    }
    return i;
}

按升序排列后,最后一个数就是最大值,倒数第二个人数就是其他数字里最大的,只需要判断这两个数即可。

2、直接找最大数和次大数

int dominantIndex(int* nums, int numsSize){
    if(numsSize==1)
        return 0;
    int max=nums[1],sec=nums[0],idx=1;


![img](https://img-blog.csdnimg.cn/img_convert/f8f6a6ffc3bbec82546c67078b42532f.png)
![img](https://img-blog.csdnimg.cn/img_convert/71360179a1c008988cbdd2a6613bbfd0.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618668825)**

深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618668825)**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值