前言:
每日一练系列,每一期都包含5道选择题,2道编程题,博主会尽可能详细地进行讲解,令初学者也能听的清晰。每日一练系列会持续更新,暑假时三天之内必有一更,到了开学之后,将看学业情况更新。
五道选择题:
1、如下程序的功能是( )
#include <stdio.h> int main() { char ch[80] = "123abcdEFG*&"; int j; puts(ch); for (j = 0; ch[j] != '\0'; j++)//1 if (ch[j] >= 'A' && ch[j] <= 'Z')//2 ch[j] = ch[j] + 'e' - 'E';//3 puts(ch); return 0; }
、 测字符数组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
2、以下程序运行时,输入 1abcedf2df<回车> 的输出结果是( )
#include <stdio.h> int main() { char ch; while ((ch = getchar()) != '\n')//1 { if (ch % 2 != 0 && (ch >= 'a' && ch <= 'z'))//2 ch = ch - 'a' + 'A';//3 putchar(ch); } printf("\n"); return 0; }
A、 1abcedf2df B、 1ABCEDF2DF
C、 1AbCEdf2df D、 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
3、以下对C语言函数的有关描述中,正确的有【多选】( )
A、 在C语言中,一个函数一般由两个部分组成,它们是函数首部和函数体
B、 函数的实参和形参可以是相同的名字
C、 在main()中定义的变量都可以在其它被调函数中直接使用
D、 在C程序中,函数调用不能出现在表达式语句中
解析:基础题,A选项是定义了,对。形参和实参可以同名,形参可以理解为实参的一份临时拷贝,在计算机存储上它们的空间是相互独立,互不影响的,故B对。当函数有返回值时是可以在其他被调函数中使用的,故C错。D选项和C错的一样。综上所述,答案为AB
4、在上下文及头文件均正常的情况下,下列代码的输出是( )
#include<stdio.h> void print(char* s) { if (*s) { print(++s); printf("%c", *s); } } int main() { char str[] = "Geneius"; print(str); return 0; }
A、suiene B、neius C、run-time error D、suieneG
解析:使用了递归调用的方式逆序打印字符串,但因为先++后使用的原因最后一个字符是打印不出来的,所以答案选A
5、给定 fun 函数如下,那么 fun(10) 的输出结果是( )
1. int fun(int x) 2. { 3. return (x == 1) ? 1 : (x + fun(x - 1)); 4. }
A、 0 B、 10 C、 55 D、 3628800
解析: 观察代码,发现当x等于1时,返回值1,不为1则递归调用。10这个数有点大,我们用3先走进去试一下,3走进去,发现不为1,走(3+fun(3-1)),所以fun(3)=(3+fun(3-1))。fun(2)接着走,2不等于1,走(2+fun(2-1)),所以fun(2)=(2+fun(2-1)),1等于1返回1,所以fun(1)=1,fun(2)=(2+1),fun(3)=3+2+1,可以看出,是个等差数列。
故fun(10)=1+2+3+4+.....+10结果为55,答案为C
编程题1:
力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台
思路:两个循环,一个循环找最大。一个循环来比较,有则返回最大元素下标,无则返回-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:
思路:简单的排序问题,以升序排序即可,可以使用冒泡排序,但没必要,我们有更好qsort函数,qsort函数直接快排,不仅效率高,而且方便。
不明白如何使用qsort函数的宝子们,可以看下博主之前写的博客
手把手教你使用qsort函数_大海里的番茄的博客-CSDN博客
#include <stdio.h> #include<string.h> int 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