【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…...
JavaScript 中的 ES|QL:利用 Apache Arrow 工具
作者:来自 Elastic Jeffrey Rengifo 学习如何将 ES|QL 与 JavaScript 的 Apache Arrow 客户端工具一起使用。 想获得 Elastic 认证吗?了解下一期 Elasticsearch Engineer 培训的时间吧! Elasticsearch 拥有众多新功能,助你为自己…...
反射获取方法和属性
Java反射获取方法 在Java中,反射(Reflection)是一种强大的机制,允许程序在运行时访问和操作类的内部属性和方法。通过反射,可以动态地创建对象、调用方法、改变属性值,这在很多Java框架中如Spring和Hiberna…...
今日科技热点速览
🔥 今日科技热点速览 🎮 任天堂Switch 2 正式发售 任天堂新一代游戏主机 Switch 2 今日正式上线发售,主打更强图形性能与沉浸式体验,支持多模态交互,受到全球玩家热捧 。 🤖 人工智能持续突破 DeepSeek-R1&…...
【Oracle】分区表
个人主页:Guiat 归属专栏:Oracle 文章目录 1. 分区表基础概述1.1 分区表的概念与优势1.2 分区类型概览1.3 分区表的工作原理 2. 范围分区 (RANGE Partitioning)2.1 基础范围分区2.1.1 按日期范围分区2.1.2 按数值范围分区 2.2 间隔分区 (INTERVAL Partit…...
OPENCV形态学基础之二腐蚀
一.腐蚀的原理 (图1) 数学表达式:dst(x,y) erode(src(x,y)) min(x,y)src(xx,yy) 腐蚀也是图像形态学的基本功能之一,腐蚀跟膨胀属于反向操作,膨胀是把图像图像变大,而腐蚀就是把图像变小。腐蚀后的图像变小变暗淡。 腐蚀…...
C# 求圆面积的程序(Program to find area of a circle)
给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...
代码规范和架构【立芯理论一】(2025.06.08)
1、代码规范的目标 代码简洁精炼、美观,可持续性好高效率高复用,可移植性好高内聚,低耦合没有冗余规范性,代码有规可循,可以看出自己当时的思考过程特殊排版,特殊语法,特殊指令,必须…...
Golang——9、反射和文件操作
反射和文件操作 1、反射1.1、reflect.TypeOf()获取任意值的类型对象1.2、reflect.ValueOf()1.3、结构体反射 2、文件操作2.1、os.Open()打开文件2.2、方式一:使用Read()读取文件2.3、方式二:bufio读取文件2.4、方式三:os.ReadFile读取2.5、写…...
【LeetCode】3309. 连接二进制表示可形成的最大数值(递归|回溯|位运算)
LeetCode 3309. 连接二进制表示可形成的最大数值(中等) 题目描述解题思路Java代码 题目描述 题目链接:LeetCode 3309. 连接二进制表示可形成的最大数值(中等) 给你一个长度为 3 的整数数组 nums。 现以某种顺序 连接…...
git: early EOF
macOS报错: Initialized empty Git repository in /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core/.git/ remote: Enumerating objects: 2691797, done. remote: Counting objects: 100% (1760/1760), done. remote: Compressing objects: 100% (636/636…...
