c语言每日一练(6)

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

五道选择题:

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

cpp 复制代码
#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;
}

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

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

cpp 复制代码
#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、在上下文及头文件均正常的情况下,下列代码的输出是( )

cpp 复制代码
#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) 的输出结果是( )

cpp 复制代码
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

编程题1:

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

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

cpp 复制代码
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博客

cpp 复制代码
#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

相关推荐
许小燚1 小时前
线性表——双向链表
数据结构·链表
董董灿是个攻城狮1 小时前
5分钟搞懂什么是窗口注意力?
算法
Dann Hiroaki1 小时前
笔记分享: 哈尔滨工业大学CS31002编译原理——02. 语法分析
笔记·算法
jz_ddk2 小时前
[学习] C语言数学库函数背后的故事:`double erf(double x)`
c语言·开发语言·学习
xiaolang_8616_wjl2 小时前
c++文字游戏_闯关打怪2.0(开源)
开发语言·c++·开源
夜月yeyue2 小时前
设计模式分析
linux·c++·stm32·单片机·嵌入式硬件
qqxhb3 小时前
零基础数据结构与算法——第四章:基础算法-排序(上)
java·数据结构·算法·冒泡·插入·选择
无小道3 小时前
c++-引用(包括完美转发,移动构造,万能引用)
c语言·开发语言·汇编·c++
晚云与城4 小时前
【数据结构】顺序表和链表
数据结构·链表
FirstFrost --sy5 小时前
数据结构之二叉树
c语言·数据结构·c++·算法·链表·深度优先·广度优先