c语言每日一练(6)

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

五道选择题:

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

#include 
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;
}

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

c语言每日一练(6)_第1张图片 

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

#include 
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

c语言每日一练(6)_第2张图片

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

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

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

#include
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

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

int fun(int x)
{
	return (x == 1) ? 1 : (x + fun(x - 1));
}

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

c语言每日一练(6)_第4张图片 

编程题1: 

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

c语言每日一练(6)_第5张图片

思路:两个循环,一个循环找最大。一个循环来比较,有则返回最大元素下标,无则返回-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:

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

c语言每日一练(6)_第6张图片

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

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

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

#include 
#include
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

你可能感兴趣的:(每日一练,c语言,算法,数据结构,c++)