2024年湖北省专升本C语言程序设计大题真题解析

2024年湖北省的专升本考试已于4月30日举行,考试中,出现了许多不同的考试题目,我在网上找到一所高校专升本的大题(好像是湖北师范的,后续会有湖北理工的大题真题解析,敬请期待),那么我们今天就来看这几道真题到底难不难。(有不对的地方欢迎指正,边学习边成长!)

题目:

 那么我们来看看怎么编写程序吧:

//1、输出菱形图案:
#include <stdio.h>
int main()
{int i, j, k;// 上半部分菱形for(i = 0; i <= 3; i++) {for(j = 0; j < i; j++) {      printf(" ");}for(k = 0; k <= 2*(3-i); k++) {printf("*");}printf("\n");}// 下半部分菱形for(i = 1; i <= 4; i++) {for(j = 0; j < 4-i; j++) {printf(" ");}for(k = 0; k < 2*i - 1; k++) { printf("*");}printf("\n");}return 0;
}
//2、输出表示式100项的和:
#include <stdio.h>int main() {int n= 100;double numerator = 1, denominator = 2; // 初始化分子和分母double sum = 0; // 初始化和为0// 循环计算前n项的和for (int i = 1; i <= n; i++) {// 根据项数的奇偶性,决定是加上还是减去当前的分数if (i % 2 == 1) {sum += numerator / denominator;} else {sum -= numerator / denominator;}// 更新分子和分母,为下一次循环做准备double temp = numerator;numerator = numerator + denominator;denominator = temp + denominator;}// 输出计算结果printf("前%d项的和为: %f\n", n, sum);return 0;
}
//3、元素交换
#include <stdio.h>// 函数声明
void findAndSwap(int arr[], int n);int main() {int arr[100]; // 假设数组最大长度为100int n = 0;// 数据输入printf("请输入数据,以-1结束输入:\n");while (1) {int num;scanf("%d", &num);if (num == -1) {break;}arr[n++] = num;}// 调用函数查找并交换findAndSwap(arr, n);// 数据输出printf("交换后的数组为:\n");for (int i = 0; i < n; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}// 函数定义
void findAndSwap(int arr[], int n) {if (n <= 1) {return; // 如果数组长度小于等于1,无需交换}int maxIndex = 0; // 最大元素的索引for (int i = 1; i < n; i++) {if (arr[i] > arr[maxIndex]) {maxIndex = i; // 更新最大元素的索引}}// 将最大元素与第一个元素交换int temp = arr[0];arr[0] = arr[maxIndex];arr[maxIndex] = temp;
}
//4、货物的输入和输出
#include <stdio.h>#define MAX_ITEMS 100
#define MAX_NAME_LENGTH 20// 货物结构体定义
typedef struct {char name[MAX_NAME_LENGTH]; // 货物名称int num; // 货物数量double price; // 货物价格
} Item;// 找到数量最多的货物名称
// 参数:
// - items: 货物数组
// - count: 货物数量
// 返回值:
// - 最多数量的货物名称
char* findMostNumerousItemName(Item items[], int count);// 找到价格最高的货物名称
// 参数:
// - items: 货物数组
// - count: 货物数量
// 返回值:
// - 最高价格的货物名称
char* findMostExpensiveItemName(Item items[], int count);// 计算仓库中所有货物的总价值
// 参数:
// - items: 货物数组
// - count: 货物数量
// 返回值:
// - 所有货物的总价值
double calculateTotalValue(Item items[], int count);int main() {int m;printf("请输入货物数量 m (m < 100): ");scanf("%d", &m);Item items[MAX_ITEMS];// 输入货物信息for (int i = 0; i < m; i++) {printf("请输入第 %d 件货物的名称、数量和价格: ", i + 1);scanf("%s %d %lf", items[i].name, &items[i].num, &items[i].price);}// 输出货物信息printf("所有货物信息如下:\n");for (int i = 0; i < m; i++) {printf("货物名称: %s, 数量: %d, 价格: %.2lf\n", items[i].name, items[i].num, items[i].price);}// 调用函数输出结果printf("数量最多的货物名称: %s\n", findMostNumerousItemName(items, m));printf("价格最高的货物名称: %s\n", findMostExpensiveItemName(items, m));printf("仓库中所有货物的总价值: %.2lf\n", calculateTotalValue(items, m));return 0;
}// 找到数量最多的货物名称的实现
char* findMostNumerousItemName(Item items[], int count) {int maxNum = 0;char* mostNumerousItemName = items[0].name;// 遍历货物数组,寻找数量最多的货物for (int i = 1; i < count; i++) {if (items[i].num > maxNum) {maxNum = items[i].num;mostNumerousItemName = items[i].name;}}return mostNumerousItemName;
}// 找到价格最高的货物名称的实现
char* findMostExpensiveItemName(Item items[], int count) {double maxPrice = 0;char* mostExpensiveItemName = items[0].name;// 遍历货物数组,寻找价格最高的货物for (int i = 1; i < count; i++) {if (items[i].price > maxPrice) {maxPrice = items[i].price;mostExpensiveItemName = items[i].name;}}return mostExpensiveItemName;
}// 计算仓库中所有货物的总价值的实现
double calculateTotalValue(Item items[], int count) {double totalValue = 0;// 遍历货物数组,累加每种货物的价值for (int i = 0; i < count; i++) {totalValue += items[i].num * items[i].price;}return totalValue;
}
总结:

           程序的思路并不复杂,可以说非常简单,专升本考试其实也就那么回事,25年备战的同学可以多看看书,多刷刷题,希望可以帮到正在备考的你!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/9661.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#中字典Dictionary与自定义类型CustomType之间的转换

C#中字典Dictionary与自定义类型CustomType之间的转换 思路&#xff1a; 可以使用反射System.Reflection来获取类的具体属性&#xff0c; 属性名称就映射字典的键Key。 新建控制台程序DictionaryCustomClassConversionDemo 第一步、新建关键转换类ConversionUtil。 类Con…

基于STM32F401RET6智能锁项目(使用库函数点灯、按键)

点灯硬件原理图 1、首先&#xff0c;我们查看一下原理图&#xff0c;找到相对应的GPIO口 LED_R低电平导通&#xff0c;LED4亮&#xff0c;所以LED_R的GPIO口需要配置一个低电平才能亮&#xff1b; LED_G低电平导通&#xff0c;LED3亮&#xff0c;所以LED_R的GPIO口需要配置一…

举办《Llama3关键技术深度解析与构建Responsible AI、算法及开发落地实战》线上高级研修讲座

举办《Llama3关键技术深度解析与构建Responsible AI、算法及开发落地实战》线上高级研修讲座

AI 资料汇总专栏

包含AI资料、大模型资料、AI最新行业发展 人工智能&#xff08;Artificial Intelligence&#xff0c;简称AI&#xff09;是一门研究如何使计算机能够具备智能行为的科学与技术。它致力于开发出能够像人类一样思考、学习、理解和决策的计算机系统。自20世纪50年代以来&#xff…

C++ 内联函数

一 宏定义带来的问题 最后ret的值是0。问题出在编译器在遇到宏时只是进行简单的宏替换。 宏的好处是没有类似于普通函数调用时的系统开销&#xff0c;并且宏定义的参数可以适宜大多数类型的数据。 宏定义也有缺点&#xff1a; 有时会产生不可预料的副作用。 二 用inline定义…

开源框架平台:功能优势多,助力数字化转型!

伴随着科技越来越发达&#xff0c;低代码技术平台、开源框架平台逐渐在各中小型企业里获得重视和青睐&#xff0c;成为助力企业实现流程化办公&#xff0c;进入数字化转型的的有力武器。在众多服务商中&#xff0c;谁拥有市场竞争力&#xff0c;谁在服务和产品方面更具核心价值…

Vue 插槽

Vue插槽是一种特殊的语法&#xff0c;用于在组件中定义可复用的模板部分。它允许开发者在组件的标记中声明一个或多个插槽&#xff0c;然后在使用该组件时&#xff0c;可以根据自己的需求将内容插入到这些插槽中。 Vue插槽分为默认插槽和具名插槽两种。 目录 默认插槽 语法…

springboot-aop-学习笔记

什么是AOP&#xff1f; AOP英文全称&#xff1a;Aspect Oriented Programming&#xff08;面向切面编程、面向方面编程&#xff09;&#xff0c;其实说白了&#xff0c;就是 需要 某个通用的方法时&#xff0c;可以创建一个模板&#xff0c;模板里面就有这些通用的方法&#xf…

effective python学习笔记_类与接口

用组合类实现多层结构而不用内置类型 例子&#xff1a;成绩单&#xff0c;存储学生各科成绩多个然后加权重&#xff0c;如果用字典类型会导致字典有多层嵌套结构 思想 当用内置类型如字典元组等结构出现超过二层的多层嵌套结构时&#xff0c;读起来会比较难懂&#xff0c;此时…

nestjs 全栈进阶--中间件

视频教程 22_nest中中间件_哔哩哔哩_bilibili 1. 介绍 在Nest.js框架中&#xff0c;中间件&#xff08;Middleware&#xff09;是一个非常重要的概念&#xff0c;它是HTTP请求和响应生命周期中的一个重要组成部分&#xff0c;允许开发者在请求到达最终的目的控制器方法之前或…

04.进程间通信

进程间通信基本概念 IPC&#xff08;Inter Process Communication&#xff09; 进程间通信 进程通信就是不同进程之间进行信息的交换或传播 为什么进程之间实现通信和困难 因为进程之间具有独立性&#xff0c;数据独立&#xff0c;程序可能独立也可能不独立&#xff08;父子进…

从面试官视角出发,聊聊产品经理的面试攻略

一、请进行自我介绍 这题基本是面试的开胃菜了&#xff0c;估计面试多的&#xff0c;自己答案都能倒背如流啦。 其实自我介绍还是蛮重要的&#xff0c;对我来说主要有 3 个作用&#xff1a;面试准备、能力预估、思维评估。 面试准备&#xff1a;面试官每天都要面 3 ~6 人&am…

Windows系统下通过nginx配置多项目

文章目录 前言大概思路实际操作记录&#xff1a;查看nginx 错误日志问下AI注意点&#xff1a; 当访问域名根路径时&#xff0c;重定向到/pc总结 前言 在windows电脑启动一个nginx 测试配置多前端项目&#xff0c;一个pc端&#xff08;vue3tsvite &#xff0c;history路由&…

【C++进阶】C++中的map和set

一、关联式容器 在初阶阶段&#xff0c;我们已经接触过STL 中的部分容器&#xff0c;比如&#xff1a; vector 、 list 、 deque&#xff0c; forward_list 等&#xff0c;这些容器统称为序列式容器&#xff0c;因为其底层为线性序列的数据结构&#xff0c;里面存储的是元素本…

ChatGLM3-6B部署与微调及微调后使用

记录ChatGLM3-6B部署及官方Lora微调示例详细步骤及如何使用微调后的模型进行推理 一、下载代码 使用git clone 命令下载源码 git clone https://github.com/THUDM/ChatGLM3.git 如图所示 二、下载模型 模型权重文件从魔塔进行下载&#xff0c;不需要翻墙。权重文件比较大&…

【docker 】push 镜像到私服

查看镜像 docker images把这个hello-world 推送到私服 docker push hello-world:latest 报错了。不能推送。需要标记镜像 标记Docker镜像 docker tag hello-world:latest 192.168.2.1:5000/hello-world:latest 将Docker镜像推送到私服 docker push 192.168.2.1:5000/hello…

设计合理的IT运维服务目录:打造高效运维的蓝图

在数字化转型的浪潮中&#xff0c;一个设计合理、内容详尽的IT运维服务目录是连接服务提供者与消费者之间的桥梁&#xff0c;它不仅体现了服务设计的专业性&#xff0c;还直接影响着运维效率和服务质量。如何设计出既合理又高效的IT运维服务目录&#xff1f;让我们结合ITIL 4框…

【全开源】JAVA台球助教台球教练多端系统源码支持微信小程序+微信公众号+H5+APP

功能介绍 球厅端&#xff1a;球厅认证、教练人数、教练的位置记录、助教申请、我的项目、签到记录、我的钱包、数据统计 教练端&#xff1a;我的页面&#xff0c;数据统计、订单详情、保证金、实名认证、服务管理、紧急求助、签到功能 用户端&#xff1a;精准分类、我的助教…

Maven的使用

1.第一个Maven工程 1.1 创建约定目录结构 ​ Hello ​ src ​ ——main(存放主程序) ​ ————java(存放源代码文件) ​ ————resources(存放配置文件和资源文件) ​ ——test(存放测试程序) ​ ————java ​ ————resources ​ pom.xml 1.2 创建核心文件 pom.xml …

mysql等保测评2.0命令-三级

版本 Win默认安装位置 C:\Program Files\MySQL\MySQL Server 8.0\bin 版本&#xff1a;select version() from dual; 身份鉴别 a应对登录的用户进行身份标识和鉴别&#xff0c;身份标识具有唯一性&#xff0c;身份鉴别信息具有复杂度要求并定期更换&#xff1b; 1、SELEC…