c语言每日一练(6)

前言:
每日一练系列,每一期都包含5道选择题,2道编程题,博主会尽可能详细地进行讲解,令初学者也能听的清晰。每日一练系列会持续更新,暑假时三天之内必有一更,到了开学之后,将看学业情况更新。

五道选择题:

1、如下程序的功能是( )

#include int main(){char ch[80] = "123abcdEFG*&";int j;puts(ch);for (j = 0; ch[j] != '\0'; j++)//1if (ch[j] >= 'A' && ch[j] <= 'Z')//2ch[j] = ch[j] + 'e' - 'E';//3puts(ch);return 0;}

A、测字符数组ch的长度
B、将数字字符串ch转换成十进制数
C、将字符数组ch中的小写字母转换成大写 D、将字符数组ch中的大写字母转换成小写

解析:观察代码构成,发现主要部分为代码1,2,3。先看代码1,代码1的意思是,只要字符不为’\0’它就会遍历下去,所以代码1这个循环会将字符串ch给遍历一遍。继续观察,循环里包含着代码2,代码2包含着代码3。代码2是个if表达式,进入代码3的条件是对应字符为大写字母,最后看下代码3,要注意的一点:a的ASCII码值为97,A的ASCII码值为65,大小写字母之间的ASCII码值是定值为32,因此,可以看出代码3的作用是将大写字母转化为小写字母,综上所述,该函数的作用是将字符串中的大写字母转化为小写字母。故选D

图片[1] - c语言每日一练(6) - MaxSSL

2、以下程序运行时,输入 1abcedf2df的输出结果是( )

#include int main(){char ch;while ((ch = getchar()) != '\n')//1{if (ch % 2 != 0 && (ch >= 'a' && ch <= 'z'))//2ch = ch - 'a' + 'A';//3putchar(ch);}printf("\n");return 0;}

A、1abcedf2df B、1ABCEDF2DF

C、1AbCEdf2dfD、1aBceDF2DF

解析:这道题与上一道题类似。观察代码,发现主要构成为代码1,2,3。可以看出代码1通过getchar将我们输入的字符串依次分解为一个个字符,并令这一个个字符依次进入代码2判定下一步操作。

看到代码2,发现代码2进入的条件得是小写字母,且对应的ASCII码值不能被2整除,a的ASCII码值为97,因此a,c,e,g……便可以进入到代码3。代码3的作用可以看出是将小写字母转化为大写字母。综上所述,我们输入 1abcedf2df 1,2不会进入,保留原样,a,c,e均被转化为大写字母,所以最后的结果为1AbCEdf2df,故选C

图片[2] - c语言每日一练(6) - MaxSSL

3、以下对C语言函数的有关描述中,正确的有【多选】( )
A、在C语言中,一个函数一般由两个部分组成,它们是函数首部和函数体
B、函数的实参和形参可以是相同的名字
C、在main()中定义的变量都可以在其它被调函数中直接使用
D、在C程序中,函数调用不能出现在表达式语句中

解析:基础题,A选项是定义了,对。形参和实参可以同名,形参可以理解为实参的一份临时拷贝,在计算机存储上它们的空间是相互独立,互不影响的,故B对。当函数有返回值时是可以在其他被调函数中使用的,故C错。D选项和C错的一样。综上所述,答案为AB

4、在上下文及头文件均正常的情况下,下列代码的输出是( )

#includevoid print(char* s){if (*s){print(++s);printf("%c", *s);}}int main(){char str[] = "Geneius";print(str);return 0;}

A、suieneB、neius C、run-time error D、suieneG

解析:使用了递归调用的方式逆序打印字符串,但因为先++后使用的原因最后一个字符是打印不出来的,所以答案选A

图片[3] - c语言每日一练(6) - MaxSSL
5、给定 fun 函数如下,那么 fun(10) 的输出结果是( )

int fun(int x){return (x == 1) " />

编程题1:

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

图片[4] - c语言每日一练(6) - MaxSSL

思路:两个循环,一个循环找最大。一个循环来比较,有则返回最大元素下标,无则返回-1

int dominantIndex(int* nums, int numsSize) {int max = 0;int i = 0;int max_order = 0;for (i = 0; i < numsSize; i++){if (max < nums[i]){max = nums[i];//找数组最大值max_order = i;//储存最大值的下标}}for (i = 0; i < numsSize; i++){if (max < nums[i] * 2 && max_order != i)//不能够和自己比{return -1;}}return max_order;}

编程题2:

图片整理_牛客题霸_牛客网

图片[5] - c语言每日一练(6) - MaxSSL

思路:简单的排序问题,以升序排序即可,可以使用冒泡排序,但没必要,我们有更好qsort函数,qsort函数直接快排,不仅效率高,而且方便。

不明白如何使用qsort函数的宝子们,可以看下博主之前写的博客

手把手教你使用qsort函数_大海里的番茄的博客-CSDN博客

#include #includeint cmp_char(const void* c1, const void* c2){return (*(char*)c1) - (*(char*)c2);}int main() {char a[1001] = { 0 };gets(a);//获得字符串int len = strlen(a);//计算字符串长度qsort(a, len, sizeof(char), cmp_char);//使用快排函数printf("%s", a);}

好了,今天的练习到这里就结束了,感谢各位友友的来访,祝各位友友前程似锦O(∩_∩)O

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享