【C/C++】常见模拟题题解
题解
- 模拟双目运算符
- 一元二次方程求解
- 水仙花数
- 统计学生成绩
- 学生成绩管理
- 模拟选举
- 大小写字符转换
- 最大公约数、最小公倍数
- 字符串反序
模拟双目运算符
编写一个根据用户键入的两个操作数和一个双目运算符,由计算机输出结果的程序。
#include<stdio.h>int operate(int a,int b,char c){switch(c){case '+': return a+b;case '-': return a-b;case '*': return a*b;case '/': return a/b;case '%': return a%b;default:printf("输入错误!\n");return 0;}
}int main() {int a,b;char c;scanf("%d %c %d",&a,&c,&b);printf("%d %c %d = %d",a,c,b,operate(a,b,c));return 0;
}
一元二次方程求解
已知文件 Coefficient.txt 中存有多个方程 ax2 + bx + c = 0 中系数 a, b, c 的值,数据按行排列,编写程序求出方程的解,并将结果写入到 result.txt 文件中,要求考虑 a, b, c 各种取值情况。
Coefficient.txt 内容举例:
5 25 3
0 2 6
0 0 0
1 1 8
......
#include<stdio.h>
#include<math.h>int main() {FILE *fp1,*fp2;if((fp1=fopen("Coefficient.txt","r"))==NULL){printf("不能打开Coefficient.txt文件\n");}if((fp2=fopen("result.txt","w"))==NULL){printf("不能打开result.txt文件\n");}double a,b,c,delta;double x1,x2;while(fscanf(fp1,"%lf %lf %lf",&a,&b,&c)!=EOF){if(a!=0){delta = b*b-4*a*c;if(delta<0){fprintf(fp2,"结果不存在\n");}else{x1=(-b+sqrt(delta))/(2*a);x2=(-b-sqrt(delta))/(2*a);fprintf(fp2,"x1=%.2lf,x2=%.2lf\n",x1,x2);}}else{if(b!=0){fprintf(fp2,"x=%.2lf\n",-c/b);}else{if(c==0){fprintf(fp2,"任意解\n");}else{fprintf(fp2,"无解\n");}}}}if(fclose(fp1)!= 0) printf("关闭Cofficient.txt文件错误\n");if(fclose(fp2)!= 0) printf("关闭result.txt文件错误\n");return 0;
}
水仙花数
打印出所有的 “水仙花数”,所谓 “水仙花数” 是指一个 3位数,其各位数字立方和等于该数本身。例如,153是一水仙花数,因为 153 = 13 + 53 + 33。
#include<stdio.h>
#include<math.h>int main() {int a, b, c;//a,b,c对应个位,十位,百位for (int i = 100; i <= 999; i++) {a = i % 10;b = i / 10 % 10;c = i / 100;if (pow(a, 3) + pow(b, 3) + pow(c, 3) == i) {printf("%d\n", i);}}return 0;
}
统计学生成绩
已知共有 30 名学生,每名学生有数学、语文、物理、化学、英语这 5 门课,班主任需要统计总分在前 10 名的同学的姓名和学号,另外特别关注这 10 名同学中有某门课程低于 80 分的同学,请编写程序实现上述功能。(若有分数相同,允许和第十名并列输出。程序添加必要的注释)
#include <stdio.h>
#define M 5
#define N 6 //6人举例typedef struct Student{char *name;char *id;double score[M];double sum;
}student;void Sort(student stu[]){student temp;for(int i=0;i<N;i++){for(int j=0;j<N-1-i;j++){if(stu[j].sum<stu[j+1].sum){temp=stu[j+1];stu[j+1]=stu[j];stu[j]=temp;}}}
}int main()
{student s[N]={{"zhang", "001",{90, 90, 80, 90, 90}},{"li", "002", {90, 80, 60, 90, 70}},{"wang", "003", {70, 40, 60, 80, 80}},{"zhao", "004", {20, 30, 80, 90, 90}},{"zhou", "005", {50, 50, 70, 80, 50}},{"liu", "006", {70, 60, 90, 90, 20}},};for(int i=0;i<N;i++){for(int j=0;j<M;j++){s[i].sum+=s[i].score[j];}}Sort(s);for(int i=0;i<N;i++){printf("学号:%s 姓名:%s 总分:%.2lf",s[i].id,s[i].name,s[i].sum);for(int j=0;j<M;j++){if(s[i].score[j]<80){switch(j+1){case 1: printf("语文低于80分!"); break;case 2: printf("数学低于80分!"); break;case 3: printf("英语低于80分!"); break;case 4: printf("物理低于80分!"); break;case 5: printf("化学低于80分!"); break;}}}printf("\n");}return 0;
}
学生成绩管理
输入 n 个学生的学号、姓名、数学成绩、语文成绩和英语成绩,求出每位学生的三门课程的总分,然后按总分由高到低排序,并将排序结果按学号、姓名、数学成绩、语文成绩、英语成绩、总分和名次打印输出到屏幕和文件 student.dat 中。要求用结构体描述学生信息,输出打印时每位学生信息占一行且上下列对齐,总分相同时名次相同。例如,假设有四个成绩为 280、275、275、250,则对应的名次为 1、2、2、4。
#include <stdio.h>
#define N 10typedef struct Student{char id[10];char name[20];double chinese;double math;double english;double sum;int rank;
}student;void Sort(student s[],int n){student temp;for(int i=0;i<n;i++){for(int j=0;j<n-1-i;j++){if(s[j].sum < s[j+1].sum){temp=s[j+1];s[j+1]=s[j];s[j]=temp;}}}
}int main()
{int n;student s[N];FILE *fp;if((fp=fopen("student.dat","w+"))==NULL){printf("打开文件错误!\n");return 0;}printf("请输入学生数量:");scanf("%d",&n);printf("请依次输入学生信息:\n");for(int i=0;i<n;i++){scanf("%s %s %lf %lf %lf",&s[i].id,&s[i].name,&s[i].chinese,&s[i].math,&s[i].english);}for(int i=0;i<n;i++){s[i].sum = s[i].chinese+s[i].math+s[i].english;}Sort(s,n);for(int i=0;i<n;i++){s[i].rank=i+1;for(int j=0;j<i;j++){if(s[i].sum==s[j].sum){s[i].rank=s[j].rank;}}}for(int i=0;i<n;i++){printf("序号:%d\t学号:%s\t姓名:%s\t语文:%.2lf\t数学:%.2lf\t英语:%.2lf\t总分:%.2lf\n",s[i].rank,s[i].id,s[i].name,s[i].chinese,s[i].math,s[i].english,s[i].sum);fprintf(fp,"序号:%d\t学号:%s\t姓名:%s\t语文:%.2lf\t数学:%.2lf\t英语:%.2lf\t总分:%.2lf\n",s[i].rank,s[i].id,s[i].name,s[i].chinese,s[i].math,s[i].english,s[i].sum);}if(fclose(fp)!=0)printf("关闭文件错误!\n");return 0;
}
001 wang 90 70 90
002 ming 70 95 70
003 gao 60 85 90
004 zhang 60 80 80
005 cai 60 85 80
模拟选举
编程模拟选举过程。假定 4 位候选人 zhang、wang、li、zhao,代号分别为 1、2、3、4。选举人直接键入候选人代号,1~4之外的整数视为弃票权,-1为终止标志。打印各位候选人的得票以及当选者(得票数超过选票总数一半)的名单。
#include <stdio.h>int main()
{int v,abandon=0,count=0;char name[4][10]={"zhang", "wang", "li", "zhao"};char vote[4]={0};while(v!=-1){printf("请选择: 1-zhang, 2-wang, 3-li, 4-zhao\n");scanf("%d",&v);switch(v){case 1 : vote[0]++;break;case 2 : vote[1]++; break;case 3 : vote[2]++; break;case 4 : vote[3]++; break;default : abandon++; break;}count++;}for(int i=0;i<4;i++){printf("%s - %d\n",name[i],vote[i]);}printf("当选者名单:");for(int i=0;i<4;i++){if(vote[i]>count/2){printf("%s\n",name[i]);}}return 0;
}
大小写字符转换
#include <stdio.h>int main()
{char ch;printf("请输入一个字符:");scanf("%c",&ch);if(ch>='a' && ch<='z'){ch-=32;printf("%c\n",ch);}else if(ch>='A' && ch<='Z'){ch+=32;printf("%c\n",ch);}else{printf("输入的不是大写或者小写字母\n");}return 0;
}
完数
编程求 1000 之内的所有 ”完数“。所谓 ”完数“ 是指一个数恰好等于它的包括 1 在内的所有不同因子之和。例如,6 是完数,因为 6 = 1 + 2 + 3。
#include<stdio.h>int f(int n){int sum = 0;for (int i = 1;i<n;i++) {if (n % i == 0) sum += i;}if (sum == n) return 1;return 0;
}int main() {for(int i=1;i<=1000;i++){if(f(i))printf("%d ",i);}return 0;
}
最大公约数、最小公倍数
#include<stdio.h>int main() {int m,n,r=0,p=0,temp;printf("请输入:");scanf("%d %d",&m,&n);if(m<n){temp=n;n=m;m=temp;}p=m*n;while(n){r=m%n;m=n;n=r;}printf("最大公约数为:%d,最小公倍数为:%d",m,p/m);return 0;
}
字符串反序
#include<stdio.h>
#include<string.h>void inverse(char str[]){char t;int i,j;for(int i=0,j=strlen(str);i<(strlen(str)/2);i++,j--){t=str[i];str[i]=str[j-1];str[j-1]=t;}
}int main() {char str[100];printf("请输入字符串:");scanf("%s",str);inverse(str);printf("输出字符串为:%s",str);return 0;
}
以上属个人见解。
❤️整理不易,希望对您有帮助,您的支持是我创作最大的动力!
相关文章:
【C/C++】常见模拟题题解
题解 模拟双目运算符一元二次方程求解水仙花数统计学生成绩学生成绩管理模拟选举大小写字符转换最大公约数、最小公倍数字符串反序 模拟双目运算符 编写一个根据用户键入的两个操作数和一个双目运算符,由计算机输出结果的程序。 #include<stdio.h>int opera…...

TikTok 购物和直播的 5 个简单技巧
TikTok 的一切都很大:应用程序下载量、受众规模和病毒式营销活动。因此,该公司多方面进军社交商务也就不足为奇了。是的,这将是巨大的。自去年年底以来,TikTok Shopping 和TikTok 直播购物活动已在一些市场上线,并将于…...

神经网络中BN层简介及位置分析
1. 简介 Batch Normalization是深度学习中常用的技巧,Batch Normalization: Accelerating Deep Network Training by Reducing Internal Covariate Shift (Ioffe and Szegedy, 2015) 第一次介绍了这个方法。 这个方法的命名,明明是Standardization, 非…...

BGP基础配置
EBGP是AS之间 IBGP是AS内 R1-R2是EBGP,R4-R5是EBGP R2-R3-R4是IBGP 第一步基础配置:IP地址 [r1-GigabitEthernet0/0/0]ip ad 12.0.0.1 24 [r1-LoopBack0]ip ad 1.1.1.1 32 [r2-GigabitEthernet0/0/0]ip ad 12.0.0.2 24 [r2-LoopBack0]ip ad 2.2.2.2 32 [r2-Loop…...

【开题报告】基于深度学习的驾驶员危险行为检测系统
研究的目的、意义及国内外发展概况 研究的目的、意义:我国每年的交通事故绝对数量是一个十分巨大的数字,造成了巨大的死亡人数和经济损失。而造成交通事故的一个很重要原因就是驾驶员的各种危险驾驶操作行为。如果道路驾驶员的驾驶行为能够得到有效识别…...
Linux云服务器打包部署前端Vue项目
1. 打包 在项目包的终端使用命令打包成dist文件。 npm run build2. Linux云服务器上创建文件夹 mkdir /home/www/dist注:dist文件夹不用创建,将打包好的dist.zip放进去,然后解压就行。 3. 安装nginx yum install -y nginx4. 修改配置文件…...

Egg.js中Cookie和Session
Cookie HTTP请求是无状态的,但是在开发时,有些情况是需要知道请求的人是谁的。为了解决这个问题,HTTP协议设计了一个特殊的请求头:Cookie。服务端可以通过响应头(set-cookie)将少量数据响应给客户端&#…...

与 PCIe 相比,CXL为何低延迟高带宽?
文章目录 前言1. LatencyPCIE 生产者消费则模型结论Flit 包PCIE/CXL.ioCXL.cace & .mem总结 2. BandWidth常见开销CXL.IO Link efficiencyPCIe Link efficiencyCXL.IO bandwidthCXL.mem/.cache bandwidth 参考 前言 CXL 规范里没有具体描述与PCIe 相比低延时高带宽的原因&…...

Vue 入门指南:从零开始学习 Vue 的基础知识
🥝VUE官方文档 注意: 📒Vue 2 将于 2023 年 12 月 31 日停止维护。详见 Vue 2 延长 LTS。📒Vue 2 中文文档已迁移至 v2.cn.vuejs.org。📒想从 Vue 2 升级?请参考迁移指南。 文章目录 🍁前言&am…...

11.docker的网络-docker0的理解及bridge网桥模式的介绍与实例
1.docker0的基本理解 安装完docker服务后,我们首先查看一下宿主机的网络配置 ifconfig我们可以看到,docker服务会默认在宿主机上创建一个虚拟网桥docker0,该网桥网络的名字称为docker0。它在内核层连通了其他物理或者虚拟网卡,这…...

新材料制造ERP用哪个好?企业应当如何挑选适用的
有些新材料存在特殊性,并且在制造过程中对车间、设备、工艺、人员等方面提出更高的要求。还有些新材料加工流程复杂,涉及多种材料的请购、出入库、使用和管理等环节,解决各个业务环节无缝衔接问题是很多制造企业面临的管理难题。 新材料制造…...

vr小鼠虚拟解剖实验教学平台减少了受感染风险
家畜解剖实验教学是培养畜牧兽医专业学生实际操作能力的专业教学活动中的核心手段。采取新型教学方式与手段,合理设置实验教学内容,有助于激发学生的操作积极性,促进实践教学的改革。 家畜解剖VR仿真教学是一种借助VR虚拟现实制作和web3d开发…...

【算法萌新闯力扣】:环形链表及环形链表II
力扣题目:环形链表及环形链表II 开篇 今天是备战蓝桥杯的第26天和算法村开营第4天。挑选了链表的黄金关卡与大家分享。 题目一:环形链表 题目链接: 141.环形链表 题目描述 方法一、哈希表 判断是否有环,可以利用哈希表,遍历…...

10.docker的网络network-概述
1.docker的网络模式 docker共有四种网路模式,分别是bridge、host、none和container. 1.1 bridge bridge,也称为虚拟网桥。在bridge模式下,为每个容器分配、配置IP等,并将容器连接到一个docker0。使用–network bridge命令指定,…...

CodeTON Round #7 (Div. 1 + Div. 2)
A.jagged Swaps 题意: 给出一个包含 n n n个数字的序列,每次可以选择一个同时大于左右两边相邻的数字,将这个数字与它右边的数字交换,问能否在经过若干次操作后使序列变为升序。 分析: 由于交换只能向后进行&#…...
剑指 Offer(第2版)面试题 10:斐波那契数列
剑指 Offer(第2版)面试题 10:斐波那契数列 剑指 Offer(第2版)面试题 10:斐波那契数列解法1:递归解法2:动态规划解法3:动态规划 - 空间优化 剑指 Offer(第2版&…...
Debian 12 / Ubuntu 22.04 安装 Docker 以及 Docker Compose 教程
Debian 12 / Ubuntu 22.04 安装 Docker 以及 Docker Compose 教程 本文将指导如何在 Debian 12 和 Ubuntu 22.04 下安装 Docker 以及 Docker Compose。 PS:本文同时适用于 Debian 11 以及 Ubuntu 20.04 什么是 Docker? Docker 是一种容器化技术&#x…...
Spark_spark参数配置优先级
总结 : 优先级低-》优先级高 spark-submit 提交的优先级 < scala/java代码中的配置参数 < spark SQL hint spark submit 中提交参数 #!/usr/bin/env bashsource /home/work/batch_job/product/common/common.sh spark_version"/home/work/opt/spark&q…...
ElasticSearch之Search settings
相关参数 indices.query.bool.max_clause_count 本参数当前已失效。 search.max_buckets 本参数用于控制在单个响应中返回的聚合的桶的数量。 默认值为65536。 本参数允许在elasticsearch.yml中配置,配置样例如下: search.max_buckets: 30或者使用Ela…...

二十二、数组(4)
本章概要 随机生成泛型和基本数组 随机生成 我们可以按照 Count.java 的结构创建一个生成随机值的工具: Rand.java import java.util.*; import java.util.function.*;import static com.example.test.ConvertTo.primitive;public interface Rand {int MOD 10_0…...

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型
摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...

深度学习在微纳光子学中的应用
深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向: 逆向设计 通过神经网络快速预测微纳结构的光学响应,替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…...
FFmpeg 低延迟同屏方案
引言 在实时互动需求激增的当下,无论是在线教育中的师生同屏演示、远程办公的屏幕共享协作,还是游戏直播的画面实时传输,低延迟同屏已成为保障用户体验的核心指标。FFmpeg 作为一款功能强大的多媒体框架,凭借其灵活的编解码、数据…...

React19源码系列之 事件插件系统
事件类别 事件类型 定义 文档 Event Event 接口表示在 EventTarget 上出现的事件。 Event - Web API | MDN UIEvent UIEvent 接口表示简单的用户界面事件。 UIEvent - Web API | MDN KeyboardEvent KeyboardEvent 对象描述了用户与键盘的交互。 KeyboardEvent - Web…...
什么是EULA和DPA
文章目录 EULA(End User License Agreement)DPA(Data Protection Agreement)一、定义与背景二、核心内容三、法律效力与责任四、实际应用与意义 EULA(End User License Agreement) 定义: EULA即…...
Matlab | matlab常用命令总结
常用命令 一、 基础操作与环境二、 矩阵与数组操作(核心)三、 绘图与可视化四、 编程与控制流五、 符号计算 (Symbolic Math Toolbox)六、 文件与数据 I/O七、 常用函数类别重要提示这是一份 MATLAB 常用命令和功能的总结,涵盖了基础操作、矩阵运算、绘图、编程和文件处理等…...

Ascend NPU上适配Step-Audio模型
1 概述 1.1 简述 Step-Audio 是业界首个集语音理解与生成控制一体化的产品级开源实时语音对话系统,支持多语言对话(如 中文,英文,日语),语音情感(如 开心,悲伤)&#x…...
AI编程--插件对比分析:CodeRider、GitHub Copilot及其他
AI编程插件对比分析:CodeRider、GitHub Copilot及其他 随着人工智能技术的快速发展,AI编程插件已成为提升开发者生产力的重要工具。CodeRider和GitHub Copilot作为市场上的领先者,分别以其独特的特性和生态系统吸引了大量开发者。本文将从功…...

tree 树组件大数据卡顿问题优化
问题背景 项目中有用到树组件用来做文件目录,但是由于这个树组件的节点越来越多,导致页面在滚动这个树组件的时候浏览器就很容易卡死。这种问题基本上都是因为dom节点太多,导致的浏览器卡顿,这里很明显就需要用到虚拟列表的技术&…...

C++使用 new 来创建动态数组
问题: 不能使用变量定义数组大小 原因: 这是因为数组在内存中是连续存储的,编译器需要在编译阶段就确定数组的大小,以便正确地分配内存空间。如果允许使用变量来定义数组的大小,那么编译器就无法在编译时确定数组的大…...