首页 星云 工具 资源 星选 资讯 热门工具
:

PDF转图片 完全免费 小红书视频下载 无水印 抖音视频下载 无水印 数字星空

2个月搞定计算机二级C语言——真题(1)解析

编程知识
2024年07月24日 16:37

1. 前言

大家好,我是梁国庆。

这段时间将持续发布计算机二级 C 语言真题的解析,想要同步练习,需要资源包的朋友可以跳转免费获取——《3个月搞定计算机二级C语言——准备工作》。

现在恐怕要改为 2 个月搞定计算机二级 C 语言了,不过没有关系,干就完了!

本篇博客将解析计算机二级 C 语言考试真题第1套,主要讲解程序填空题、程序修改题和程序设计题,选择题就不说了,主要我也没做。

在做题之前我先啰嗦两句,编程题的难易程度只有读了题目才知道,不要看着题目要求的字多就觉得难,其实那题纸老虎一个,就算是个硬骨头,我们照样能给它嚼碎了。

image

2. 程序填空题

2.1 题目要求

image

2.2 提供的代码

#include <stdio.h>
#pragma warning(disable : 4996)
void fun(char c, int d) {
    int  i;
    char A[26], a[26], *ptr;
    /**********found**********/
    for (i = 0; i < ___(1) ____; i++) {
        A[i] = 'A' + i;
        a[i] = 'a' + i;
    }
    /**********found**********/
    if ((c >= 'a') && (c ___(2) ____ 'z'))
        ptr = a;
    else
        ptr = A;
    /**********found**********/
    for (i = 1; i <= d; i++)
        printf("%c", ptr[(c - ptr[0] + i) % ____(3) ____]);
}
main() {
    char c;
    int  d;
    printf("please input c & d:\n");
    scanf("%c%d", &c, &d);
    fun(c, d);
}

2.3 解题思路

(1)处填空:for 循环的作用是初始化数组 A[]、a[],将大写字母、小写字母分别存入数组 A[]、a[],我们知道英文字母一共有 26 个,所以这里需要循环 26 次。

for 循环控制变量 i 的初始值是 0,在 i<___(1)____ 时结束,这里的关系运算符是 < 而非 <=,这就意味着在 < 后面填几就会循环几次,这里我们填入 26,则 i 从 0 加至 25 后停止循环,循环次数为 26 次。

for (i = 0; i < 26; i++)

(2)处填空:if 判断的作用是判断 fun 函数的形参 c 的字符范围。

实际是在判断传入的形参 c 是小写字母还是大写字母,若是小写字母,则将存储小写字母的数组 a 的首地址赋值给指针 ptr,若不是则将存储大写字母的数组 A 的首地址赋值给指针 ptr

在 C 语言中,指针可以像数组一样使用,这是因为数组名实际上是一个指向数组第一个元素(即首地址)的指针。我们可以通过指针来访问数组元素,并且指针和数组有许多相似的操作方式。

所以这里只需填入 <=,使其判断范围控制在 'a' ~ 'z' 即可。

if ((c >= 'a') && (c <= 'z'))

(3)处填空:前面将数组 a/A 的首地址赋值给了指针 ptr,指针 ptr 便可以当作数组来使用。

这里需要让 ptr 的下标变为 0,从而打印字符 'A' 或 'a',所以除 26 取余。

printf("%c", ptr[(c - ptr[0] + i) % 26]);

2.4 代码实现

填写完整的代码:

#include <stdio.h>
#pragma warning(disable : 4996)
void fun(char c, int d) {
    int  i;
    char A[26], a[26], *ptr;
    /**********found**********/
    for (i = 0; i < 26; i++) {
        A[i] = 'A' + i;
        a[i] = 'a' + i;
    }
    /**********found**********/
    if ((c >= 'a') && (c <= 'z'))
        ptr = a;
    else
        ptr = A;
    /**********found**********/
    for (i = 1; i <= d; i++)
        printf("%c", ptr[(c - ptr[0] + i) % 26]);
}
main() {
    char c;
    int  d;
    printf("please input c & d:\n");
    scanf("%c%d", &c, &d);
    fun(c, d);
}

提示:为确保代码正常运行,请在题库编程环境的对应题目中进行测试和运行。

3. 程序修改题

3.1 题目要求

image

3.2 提供的代码

#include <stdio.h>
#pragma warning(disable : 4996)
void fun(char* p, char* b) {
    int i, k = 0;
    while (*p) {
        i = 1;
        while (i <= 3 && *p) {
            /**********found**********/
            b[k] = p;
            k++;
            p++;
            i++;
        }
        if (*p) {
            /**********found**********/
            b[k++] = " ";
        }
    }
    b[k] = '\0';
}
main() {
    char a[80], b[80];
    printf("Enter a string:      ");
    gets(a);
    printf("The original string: ");
    puts(a);
    fun(a, b);
    printf("\nThe string after insert space:   ");
    puts(b);
    printf("\n\n");
    getchar();
}

3.3 解题思路

(1)处修改:p 是一个 char* 类型的指针,提供的代码试图将其直接赋值给 b[k],而 b[k] 是一个 char 类型的字符。很明显这是行不通的,因为 b[k] 只能存储单个字符,而不是指针。

我们需要进行解引用操作*p),即访问指针 p 所指向的内存地址中的值,在 p 的前面加上解引用运算符 *

b[k] = *p;

(2)处修改:" " 是一个字符串常量,它实际上是一个 char* 类型的指针,而 b[k++] 只能存储单个字符。' ' 是一个字符常量,所以将 " " 换为 ' ' 即可。

b[k++] = ' ';

3.4 代码实现

修改后的代码:

#include <stdio.h>
#pragma warning(disable : 4996)
void fun(char* p, char* b) {
    int i, k = 0;
    while (*p) {
        i = 1;
        while (i <= 3 && *p) {
            /**********found**********/
            b[k] = *p;
            k++;
            p++;
            i++;
        }
        if (*p) {
            /**********found**********/
            b[k++] = ' ';
        }
    }
    b[k] = '\0';
}
main() {
    char a[80], b[80];
    printf("Enter a string:      ");
    gets(a);
    printf("The original string: ");
    puts(a);
    fun(a, b);
    printf("\nThe string after insert space:   ");
    puts(b);
    printf("\n\n");
    getchar();
}

提示:为确保代码正常运行,请在题库编程环境的对应题目中进行测试和运行。

4. 程序设计题

4.1 题目要求

image

4.2 提供的代码

#include <stdio.h>
#include <string.h>
void fun(char* ss) {
}

void main(void) {
    char tt[51];
    void NONO();
    printf("\nPlease enter an character string within 50 characters:\n");
    gets(tt);
    printf("\n\nAfter changing, the string\n  \"%s\"", tt);
    fun(tt);
    printf("\nbecomes\n  \"%s\"", tt);
    NONO();
    getchar();
}

void NONO() {
    /* 请在此函数内打开文件,输入测试数据,调用 fun 函数,
       输出数据,关闭文件。 */
    char  tt[51], ch;
    FILE *rf, *wf;
    int   len, i = 0;

    rf = fopen("in.dat", "r");
    wf = fopen("out.dat", "w");
    while (i < 10) {
        fgets(tt, 50, rf);
        len = strlen(tt) - 1;
        ch  = tt[len];
        if (ch == '\n' || ch == 0x1a)
            tt[len] = 0;
        fun(tt);
        fprintf(wf, "%s\n", tt);
        i++;
    }
    fclose(rf);
    fclose(wf);
}

4.3 解题思路

根据题目可以看出,程序中需要一个变量作为形参字符串 ss 的下标,可以将它初始化为 1,即从奇数下标开始读取字符串。在循环中遍历字符串中的奇数下标,判断该位置上的字母是否为小写字母,是则转换为大写字母

整体思路是这样的,那么对于大家来说可能的难点在哪?

  • 如何判断字符串是否结束
  • 如何将小写字母转为大写字母

PS:程序填空题的第二个空是判断字母是否为小写字母的,用 if 函数两个条件与一下就可以,这里不展开说了。

如何判断字符串是否结束

在 C 语言中,字符串是以空字符 '\0'(ASCII 值为 0)结尾的,这就意味着我们可以判断字符串当前下标中存储的是否为空字符 '\0',是则字符串结束,否则字符串未结束。

循环可以这样用:

while (ss[i] != '\0') {
    // 其他操作
    i++;
}

如何将小写字母转为大写字母

大小写转换需要用到 ASCII 编码表——《ASCII Table》。

对 ASCII 编码表熟悉的朋友应该了解,小写字母和大写字母有固定的偏移量,即对于任何一个小写字母和它对应的大写字母,它们的 ASCII 值相差 32。

如果你知道相差是 32,直接用小写字母减去 32 便得到了对应的大写字母。

ss[i] -= 32;

不知道也没有关系,可以写程序让计算机算出来,通过小写字母减去大写字母的方式求出偏移量,即 'a' - 'A' ,结果为 32。

那么假设 ss[i] 是小写字母 'c',其 ASCII 值是 99,'a' - 'A' 等于 32,所以 'c' - 32 就是对应的大写字母 'C' 的 ASCII 值,即 67。

ss[i] -= ('a' - 'A');

这样即可将小写字母转为大写字母。

4.4 代码实现

填写完整的代码:

#include <stdio.h>
#include <string.h>
void fun(char* ss) {
    int i = 1;

    while (ss[i] != '\0') {
        if ((ss[i] >= 'a') && (ss[i] <= 'z')) {
            ss[i] -= ('a' - 'A');
        }

        i += 2;
    }
}

void main(void) {
    char tt[51];
    void NONO();
    printf("\nPlease enter an character string within 50 characters:\n");
    gets(tt);
    printf("\n\nAfter changing, the string\n  \"%s\"", tt);
    fun(tt);
    printf("\nbecomes\n  \"%s\"", tt);
    NONO();
    getchar();
}

void NONO() {
    /* 请在此函数内打开文件,输入测试数据,调用 fun 函数,
       输出数据,关闭文件。 */
    char  tt[51], ch;
    FILE *rf, *wf;
    int   len, i = 0;

    rf = fopen("in.dat", "r");
    wf = fopen("out.dat", "w");
    while (i < 10) {
        fgets(tt, 50, rf);
        len = strlen(tt) - 1;
        ch  = tt[len];
        if (ch == '\n' || ch == 0x1a)
            tt[len] = 0;
        fun(tt);
        fprintf(wf, "%s\n", tt);
        i++;
    }
    fclose(rf);
    fclose(wf);
}

提示:为确保代码正常运行,请在题库编程环境的对应题目中进行测试和运行。

5. 后记

本篇博客解析了程序填空题、程序修改题和程序设计题,提供了详细的解题思路和代码实现。希望通过这些解析,大家能更好地理解和掌握,欢迎大家在留言区讨论和提问。

对于本篇博客的解题思路、代码实现以及文章架构,如果您有建议或意见欢迎您在留言区留言。

From:https://www.cnblogs.com/main-studio/p/18319747
本文地址: http://shuzixingkong.net/article/381
0评论
提交 加载更多评论
其他文章 博弈论
一、要素 局中人:在一场竞赛或博弈中,每一个有决策权的参与者成为一个局中人。只有两个局中人的博弈现象称为“两人博弈”,而多于两个局中人的博弈称为“多人博弈”。 策略:一局博弈中,每个局中人都有选择实际可行的完整的行动方案,即方案不是某阶段的行动方案,而是指导整个行动的一个方案,一个局中人的一个可行的
博弈论 博弈论 博弈论
RestSharp编写api接口测试,并实现异步调用(不卡顿)
首先,确保你已经安装了RestSharp NuGet包。如果没有安装,可以通过以下命令安装: bash Install-Package RestSharp 然后,在你的C#代码中,你可以按照以下步骤操作: 引用RestSharp命名空间。 创建一个RestClient实例。 创建一个RestRequ
DASCTF 2023 & 0X401七月暑期挑战赛【PWN】(FileEditor篇)
DASCTF 2023 &amp; 0X401七月暑期挑战赛【PWN】(FileEditor篇) 题目保护情况(保护全家桶) 64位ida逆向 模拟了一个类似vim的功能,有打开文件,打印内容,插入行,删除行,复制行,和编辑行,还有查找字符和替换字符的功能,然后就是保存退出 一个一个来分析吧 1.o
DASCTF 2023 & 0X401七月暑期挑战赛【PWN】(FileEditor篇) DASCTF 2023 & 0X401七月暑期挑战赛【PWN】(FileEditor篇) DASCTF 2023 & 0X401七月暑期挑战赛【PWN】(FileEditor篇)
Android Spingboot 实现SSE通信案例
SSE SSE(Server-Sent Events)是一种用于实现服务器主动向客户端推送数据的技术,它基于 HTTP 协议,利用了其长连接特性,在客户端与服务器之间建立一条持久化连接,并通过这条连接实现服务器向客户端的实时数据推送。 Server-Sent Events (SSE) 和 Socke
Android Spingboot 实现SSE通信案例 Android Spingboot 实现SSE通信案例 Android Spingboot 实现SSE通信案例
AI知识库这事儿FastGPT是专业的
在搭建AI知识库这事儿上,有不少成熟的框架,我推荐使用FastGPT。这篇文章笔者就使用过的两款平台做个比较,FastGPT和百度千帆平台。
AI知识库这事儿FastGPT是专业的 AI知识库这事儿FastGPT是专业的 AI知识库这事儿FastGPT是专业的
Centos7下安装配置最新版本Jenkins(2.452.3)
1、基础环境配置 1.1 服务器下载Jenkins安装包 下载地址:https://www.jenkins.io/download/ 下载命令:wget https://get.jenkins.io/war-stable/2.452.3/jenkins.war 1.2 服务器安装配置JDK Jenk
Centos7下安装配置最新版本Jenkins(2.452.3) Centos7下安装配置最新版本Jenkins(2.452.3) Centos7下安装配置最新版本Jenkins(2.452.3)
Nacos 高级详解:提升你的开发和部署效率
Nacos 高级 一 、服务集群 需求 服务提供者搭建集群 服务调用者,依次显示集群中各服务的信息 搭建 修改服务提供方的controller,打印服务端端口号 package com.czxy.controller; import org.springframework.web.bind.anno
Nacos 高级详解:提升你的开发和部署效率 Nacos 高级详解:提升你的开发和部署效率 Nacos 高级详解:提升你的开发和部署效率
Spectre.Console.Cli注入服务的几种姿势
Spectre.Console大家可能都不陌生,写控制台程序美化还是不错的,支持着色,表格,图标等相当nice,如果对这个库不熟悉我强烈推荐你了解一下,对于写一些CLI小工具还是相当方便的, 本文主要讲讲 Spectre.Console.Cli的服务注入, TA是 Spectre.Console 库
Spectre.Console.Cli注入服务的几种姿势