当前位置: 首页 > news >正文

【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++】常见模拟题题解

题解 模拟双目运算符一元二次方程求解水仙花数统计学生成绩学生成绩管理模拟选举大小写字符转换最大公约数、最小公倍数字符串反序 模拟双目运算符 编写一个根据用户键入的两个操作数和一个双目运算符&#xff0c;由计算机输出结果的程序。 #include<stdio.h>int opera…...

TikTok 购物和直播的 5 个简单技巧

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

神经网络中BN层简介及位置分析

1. 简介 Batch Normalization是深度学习中常用的技巧&#xff0c;Batch Normalization: Accelerating Deep Network Training by Reducing Internal Covariate Shift (Ioffe and Szegedy, 2015) 第一次介绍了这个方法。 这个方法的命名&#xff0c;明明是Standardization, 非…...

BGP基础配置

EBGP是AS之间 IBGP是AS内 R1-R2是EBGP,R4-R5是EBGP R2-R3-R4是IBGP 第一步基础配置&#xff1a;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…...

【开题报告】基于深度学习的驾驶员危险行为检测系统

研究的目的、意义及国内外发展概况 研究的目的、意义&#xff1a;我国每年的交通事故绝对数量是一个十分巨大的数字&#xff0c;造成了巨大的死亡人数和经济损失。而造成交通事故的一个很重要原因就是驾驶员的各种危险驾驶操作行为。如果道路驾驶员的驾驶行为能够得到有效识别…...

Linux云服务器打包部署前端Vue项目

1. 打包 在项目包的终端使用命令打包成dist文件。 npm run build2. Linux云服务器上创建文件夹 mkdir /home/www/dist注&#xff1a;dist文件夹不用创建&#xff0c;将打包好的dist.zip放进去&#xff0c;然后解压就行。 3. 安装nginx yum install -y nginx4. 修改配置文件…...

Egg.js中Cookie和Session

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

与 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 的基础知识

&#x1f95d;VUE官方文档 注意&#xff1a; &#x1f4d2;Vue 2 将于 2023 年 12 月 31 日停止维护。详见 Vue 2 延长 LTS。&#x1f4d2;Vue 2 中文文档已迁移至 v2.cn.vuejs.org。&#x1f4d2;想从 Vue 2 升级&#xff1f;请参考迁移指南。 文章目录 &#x1f341;前言&am…...

11.docker的网络-docker0的理解及bridge网桥模式的介绍与实例

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

新材料制造ERP用哪个好?企业应当如何挑选适用的

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

vr小鼠虚拟解剖实验教学平台减少了受感染风险

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

【算法萌新闯力扣】:环形链表及环形链表II

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

10.docker的网络network-概述

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

CodeTON Round #7 (Div. 1 + Div. 2)

A.jagged Swaps 题意&#xff1a; 给出一个包含 n n n个数字的序列&#xff0c;每次可以选择一个同时大于左右两边相邻的数字&#xff0c;将这个数字与它右边的数字交换&#xff0c;问能否在经过若干次操作后使序列变为升序。 分析&#xff1a; 由于交换只能向后进行&#…...

剑指 Offer(第2版)面试题 10:斐波那契数列

剑指 Offer&#xff08;第2版&#xff09;面试题 10&#xff1a;斐波那契数列 剑指 Offer&#xff08;第2版&#xff09;面试题 10&#xff1a;斐波那契数列解法1&#xff1a;递归解法2&#xff1a;动态规划解法3&#xff1a;动态规划 - 空间优化 剑指 Offer&#xff08;第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&#xff1a;本文同时适用于 Debian 11 以及 Ubuntu 20.04 什么是 Docker&#xff1f; Docker 是一种容器化技术&#x…...

Spark_spark参数配置优先级

总结 &#xff1a; 优先级低-》优先级高 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中配置&#xff0c;配置样例如下&#xff1a; search.max_buckets: 30或者使用Ela…...

二十二、数组(4)

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

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…...

[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解

突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 ​安全措施依赖问题​ GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...

shell脚本--常见案例

1、自动备份文件或目录 2、批量重命名文件 3、查找并删除指定名称的文件&#xff1a; 4、批量删除文件 5、查找并替换文件内容 6、批量创建文件 7、创建文件夹并移动文件 8、在文件夹中查找文件...

SCAU期末笔记 - 数据分析与数据挖掘题库解析

这门怎么题库答案不全啊日 来简单学一下子来 一、选择题&#xff08;可多选&#xff09; 将原始数据进行集成、变换、维度规约、数值规约是在以下哪个步骤的任务?(C) A. 频繁模式挖掘 B.分类和预测 C.数据预处理 D.数据流挖掘 A. 频繁模式挖掘&#xff1a;专注于发现数据中…...

2024年赣州旅游投资集团社会招聘笔试真

2024年赣州旅游投资集团社会招聘笔试真 题 ( 满 分 1 0 0 分 时 间 1 2 0 分 钟 ) 一、单选题(每题只有一个正确答案,答错、不答或多答均不得分) 1.纪要的特点不包括()。 A.概括重点 B.指导传达 C. 客观纪实 D.有言必录 【答案】: D 2.1864年,()预言了电磁波的存在,并指出…...

在 Nginx Stream 层“改写”MQTT ngx_stream_mqtt_filter_module

1、为什么要修改 CONNECT 报文&#xff1f; 多租户隔离&#xff1a;自动为接入设备追加租户前缀&#xff0c;后端按 ClientID 拆分队列。零代码鉴权&#xff1a;将入站用户名替换为 OAuth Access-Token&#xff0c;后端 Broker 统一校验。灰度发布&#xff1a;根据 IP/地理位写…...

从零实现STL哈希容器:unordered_map/unordered_set封装详解

本篇文章是对C学习的STL哈希容器自主实现部分的学习分享 希望也能为你带来些帮助~ 那咱们废话不多说&#xff0c;直接开始吧&#xff01; 一、源码结构分析 1. SGISTL30实现剖析 // hash_set核心结构 template <class Value, class HashFcn, ...> class hash_set {ty…...

精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南

精益数据分析&#xff08;97/126&#xff09;&#xff1a;邮件营销与用户参与度的关键指标优化指南 在数字化营销时代&#xff0c;邮件列表效度、用户参与度和网站性能等指标往往决定着创业公司的增长成败。今天&#xff0c;我们将深入解析邮件打开率、网站可用性、页面参与时…...

【7色560页】职场可视化逻辑图高级数据分析PPT模版

7种色调职场工作汇报PPT&#xff0c;橙蓝、黑红、红蓝、蓝橙灰、浅蓝、浅绿、深蓝七种色调模版 【7色560页】职场可视化逻辑图高级数据分析PPT模版&#xff1a;职场可视化逻辑图分析PPT模版https://pan.quark.cn/s/78aeabbd92d1...

回溯算法学习

一、电话号码的字母组合 import java.util.ArrayList; import java.util.List;import javax.management.loading.PrivateClassLoader;public class letterCombinations {private static final String[] KEYPAD {"", //0"", //1"abc", //2"…...