考研机试C++题目精选

更多内容会在godownio.github.io更新

算法练习(C++代码)

考研上机或C语言代码笔试准备,暨大机试原题+letcode+牛客+中南大等高校机试

快速幂算法

题目:输入一个整数 n ,求 n^n 的个位数是多少。

快速幂算法:指数为偶数,则底数平方,指数除二;指数为奇数,则指数减一再把结果乘底数,底数平方,指数除二。指数看作二进制,除二可以看作位运算。

#include <iostream>using namespace std;
int main(){int n;cin>>n;int power=n;int base=n;int result = 1;while(power>0){if(power%2==1){result *= base;power /= 2;base *= base;//指数为奇数,先乘底数。除二小数部分舍去。底数平方 }else{power /= 2;base *= base;//指数为偶数,除二,底数平方 }}cout<<result<<endl; cout<<result%10;//mod 10即个位数
}

image-20240301105155142

斐波那契

输入一个整数 n ,求斐波那契数列的第 n 项。第一项是1, 第二项是1。要求必须递归!

#include <iostream>using namespace std;int f(int n){if(n==1||n==2){return 1;}else return f(n-2)+f(n-1);
}int main(){int n;cin >> n;cout<<f(n);
}

成绩排名

对 n 个同学的考试成绩从大到小排名,成绩相同的算同一名。求排名为 m 的成绩。若无排名为m的成绩,输出最后一名的成绩。

  • 输入格式

一共三行

第一行:一个整数 n,表示同学的个数。

第二行:n 个整数,表示 n 个同学的成绩。

第三行:一个整数 m,表示排名。

  • 输出格式

一个整数,表示排名为 m 的成绩。

  • 输入样例

6
100 100 99 98 97

2

  • 输出样例

99

#include <iostream>using namespace std;
int main(){int n,m;cout<<"输入同学个数:"<<endl;cin>>n;int score[n];cout<<"输入同学的成绩:"<<endl;for (int i=0;i<n;i++){cin>>score[i];}//cout<<"1";for (int i=0;i<n;i++){for(int j=n-i-1;j>0;j--){if(score[j]>score[j-1]){int temp = score[j];score[j] = score[j-1];score[j-1] = temp;}}//冒泡排序}int i=0,j;for(j=1;j<n;j++){if(score[j]!=score[i]){score[++i]=score[j];}}//双指针去重cout<<"输入要查询的排名:"<<endl;cin>>m;if(m>i+1){cout<<score[i]<<endl; }else{cout<<score[m-1];}
}

括号匹配

给定三种括号{ },[ ], ( ),和若干小写字母的字符串,请问改字符串的括号是否匹配(可以嵌套)?

  • 输入输出

输入格式:字符串s。 输出格式:若匹配,输出yes,否则输出no。

  • 输入样例
{[a(v)d]q}
  • 输出样例
yes
#include <iostream>
#include <stack>using namespace std;
int main(){stack <int> s;string strs;cin>>strs;int m = strs.length();for (int i=0;i<m;i++){if(strs[i]=='('||strs[i]=='{'||strs[i]=='['){s.push(strs[i]);}if(strs[i]==')'){if(!s.empty()&&s.top()=='(') s.pop();else{cout<<"不匹配"; return 0;}}else if(strs[i]=='}'){if(!s.empty()&&s.top()=='{') s.pop();else{cout<<"不匹配"; return 0;}}else if(strs[i]==']'){if(!s.empty()&&s.top()=='[') s.pop();else{cout<<"不匹配"; return 0;}}//特别注意,栈为空s.top()不返回NULL,而是程序出错}if (s.empty()) cout<<"匹配成功";else cout<<"匹配失败";return 0;
} 

letcode&牛客dp+链表

不同路径

image-20240301105643910

先看递归解决:很明显从右下角开始思考,有从上和从左过来两种方式,即等于左和上路径条数之和。1*2,1*3…等很明显只有一条路径,即m or n一个为1,则返回1

#include <iostream>using namespace std;int path(int m,int n){if(m>1&&n>1){return path(m-1,n)+path(m,n-1);}else return 1;//1*2或者2*1或者1*6的路径选择都为1个 
}int main(){int m,n;cin>>m>>n;cout<<path(m,n);
}

很遗憾,递归不满足时间复杂度。

非递归解决:定义一个dp数组,记录每个格子的路径条数,即除一行一列外,每个格子的路径条数都等于上+左

#include <iostream>using namespace std;int path(int m,int n){int dp[m][n];for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(j>0&&i>0){dp[i][j]=dp[i-1][j]+dp[i][j-1];}else{dp[i][j]=1;}}}return dp[m-1][n-1];
}int main(){int m,n;cin>>m>>n;cout<<path(m,n);
}

image-20240301112745113

障碍物版不同路径

image-20240301112906322

首先,怎么输入和传参二维数组?

不能直接向某个变量cin二维数组,只能先输入行和列,然后再逐个输入,传参就用vector,因为C++传参定长,不能使用int[][] matrix,而是int matrix[][3]这种,不如使用vector方便

其次,障碍物点到达它的路径条数为0,其余按照上个题目进行计算即可

不能直接把数组传给vector,需要先进行类型转换:

int arr[rows][cols] = {{0, 0, 0}, {0, 1, 0}, {0, 0, 0}};// 将数组转换为 std::vectorvector<vector<int>> matrix;for (int i = 0; i < rows; ++i) {matrix.push_back(vector<int>(begin(arr[i]), end(arr[i])));}

注意:devC++的标准无法读取vector库,需要在编译选项->添加参数"–std=c++11"

image-20240301154601417

image-20240301154628495

#include <iostream>
#include <vector>using namespace std;
int path(vector<vector<int>>& block){int m=block.size(),n=block[0].size();vector<vector<int>> dp(m,vector<int>(n));for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(block[i][j]==0){if(j>0&&i>0){dp[i][j]=dp[i-1][j]+dp[i][j-1];}else{dp[i][j]=1;//第一行或第一列}}else{dp[i][j]=0;//有障碍物}}}return dp[m-1][n-1];
}
int main(){int rows,cols;cout<<"请输入行数和列数:"<<endl;cin>>rows>>cols;vector<vector<int>> block(rows,vector<int>(cols));cout<<"请依次输入矩阵:"<<endl;for(int i=0;i<rows;i++){for(int j=0;j<cols;j++){cin>>block[i][j];}}cout<<"左上到右下路径条数为:"<<path(block);return 0;
}

秒了

image-20240301154356385

最小路径和

太经典了,和回复祝顺利一样经典

image-20240301155000648

根据上两道题,不难猜出每个位置的dp最小值为min(上,左)+本块值,第一行则只能左+本块值,第一列则只能上+本块值,秒了

#include <iostream>
#include <vector>using namespace std;
int min(int n,int m){if(n>m) return m;else return n;
}
int path(vector<vector<int>>& block){int m=block.size(),n=block[0].size();vector<vector<int>> dp(m,vector<int>(n));dp[0][0]=block[0][0];for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(i>0&&j==0){dp[i][j]=dp[i-1][j]+block[i][j];//第一行}if(j>0&&i==0){dp[i][j]=dp[i][j-1]+block[i][j];//第一列}if(j>0&&i>0){dp[i][j]=min(dp[i][j-1],dp[i-1][j])+block[i][j];}}}return dp[m-1][n-1];
}
int main(){int rows,cols;cout<<"请输入行数和列数:"<<endl;cin>>rows>>cols;vector<vector<int>> block(rows,vector<int>(cols));cout<<"请依次输入矩阵:"<<endl;for(int i=0;i<rows;i++){for(int j=0;j<cols;j++){cin>>block[i][j];}}cout<<"左上到右下最短路径和为:"<<path(block);return 0;
}

image-20240301161828856

image-20240301161842319

image-20240301161914523

other 机试题

中南大上机压轴

506ec55b1cc642a7afb2c28c5d175ce8

水印是我的CSDN号

  • 测试数据:

3 500
0.6 100
0.8 200
0.7 100
输出 390

​ 首先要对输入的折扣进行排序,优先使用比率低的z进行支付。
​ 然后用lowcost记录目前多少钱是打过折的。T-lowcost就是剩余没打折的。
​ 每次循环用上一个人的折扣额度。若所有人折扣额度相加低于总价,则最后剩的部分就不打折

#include <iostream>
using namespace std;int paychase(int N,int T,double *z,int* H){int lowcost = 0;for(int i=0;i<N;i++){if(T<=lowcost+z[i]*H[i]){T = lowcost + (T-lowcost)*H[i];return T;}//菜品总价小于折扣else{lowcost = lowcost + z[i]*H[i];//lowcost为当前折扣限度,比如第二轮中就是0.6*100+0.8*200cout<<"lowcost:"<<lowcost<<endl;T = T - H[i] + z[i]*H[i];//折扣cout<<"T:"<<T<<endl;}}return T;
}int main(){int N,T;cout<<"请输入人数和菜品总价:"<<endl;cin>>N>>T;double z[N];int H[N];cout<<"请输入每个的折扣率和折扣上限:"<<endl;for(int i=0;i<N;i++){//cout<<i<<endl;cin>>z[i]>>H[i];}for (int i=0;i<N;i++){for (int j=i;j<N;j++){if(z[j]>z[i]){double tempz;int tempH;tempz=z[j];z[j]=z[i];z[i]=tempz;tempH=H[j];H[j]=H[i];H[i]=tempH;}}//折扣排序}int cost = paychase(N,T,z,H);cout<<"本次用餐总花费:"<<cost<<endl;return 0;
}

日期

输入日期yyyymm dd,输出是本年第几天。

本题主要知识点:年份满足以下条件之一为闰年,2月有29天:

  • 年份能被4整除,不能被100整除
  • 年份能被400整除

代码不写了

C语言考点

指针数组,数组指针

区分int (*p)[3] int *p[3]

  • 指针数组:int *p[3],实际上是个数组,只是里面元素都存放的指针,指针指向int型变量地址。
  • 数组指针:int (*p)[3],优先级()>[]>*,实际上是定义的一个指针,指向一个包含三个整数的数组。
int **p

int **p是一个指针的指针。

赋值判断

int *a=&b(√)

int a=&b(×)

int *a; a=&b(√)

记住只有指针才能存地址,整型那些都不能存地址。以及int *a后,*a才是取值,a是指向的地址。

后文会更密码学和C易错点记录

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

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

相关文章

【复试2.293.1】c语言——基础杂项

1.define定义常量类似全局变量&#xff0c;引用是直接拼到代码中去。 2.关于e 3.参数传递 形参直接接收的是数组的起始地址 4.数组越界乱码问题 5.scanf读字符串的时候会自动在末尾放0&#xff08;结束符 6.scanf是读取输入缓冲区的数据&#xff0c;是一种拿走操作。读取若有…

文本多分类

还在用BERT做文本分类&#xff1f;分享一套基于预训练模型ERNIR3.0的文本多分类全流程实例【文本分类】_ernir 文本分类-CSDN博客 /usr/bin/python3 -m pip install --upgrade pip python3-c"import platform;print(platform.architecture()[0]);print(platform.machine…

Linux第67步_linux字符设备驱动_注册和注销

1、字符设备注册与注销的函数原型” /*字符设备注册的函数原型*/ static inline int register_chrdev(unsigned int major,\ const char *name, \ const struct file_operations *fops) /* major:主设备号&#xff0c;Limnux下每个设备都有一个设备号&#xff0c;设备号分…

【六袆 - React】Next.js:React 开发框架;Next.js开发框架的特点

Next.js&#xff1a;React 开发框架 Next.js的特点 1.直观的、基于页面的路由系统&#xff08;并支持动态路由&#xff09; Next.js 提供了基于文件系统的路由&#xff0c;意味着你可以通过创建页面文件来定义路由。 伪代码示例&#xff1a; // pages/index.js export defa…

MYSQL--JDBC优化

一.JDBC优化: 优化前提: 有时候我们并不清楚某些表当中一共有多少列,以及这些列的数据类型,这个时候我们就需要提前通过一些方法提前了解到这些数据,从而更好的进行输出 具体语句: package cn.jdbc;import java.sql.*;public class JDBCDEmo1 {public static void main(String…

【数学建模获奖经验】2023第八届数维杯数学建模:华中科技大学本科组创新奖获奖分享

2024年第九届数维杯大学生数学建模挑战赛将于&#xff1a;2024年5月10日08:00-5月13日09:00举行&#xff0c;近期同学们都开始陆续进入了备赛阶段&#xff0c;今天我们就一起来看看上一届优秀的创新奖选手都有什么获奖感言吧~希望能帮到更多热爱数学建模的同学。据说点赞的大佬…

elment-ui table表格排序后 清除排序箭头/恢复默认排序 的高亮样式

问题描述&#xff1a; 1.默认排序是按照名称升序排列&#xff08;图一&#xff09; 2.在选择了筛选项以及其他排序方式之后&#xff0c;箭头高亮是这样的&#xff08;图二&#xff09; 3.当我点击清空按钮后&#xff0c;类型清空了&#xff0c;并且传给后端的排序方式是名称/升…

探索色彩搭配的奥秘:如何选择适合产品的理想配色方案

title: 探索色彩搭配的奥秘&#xff1a;如何选择适合产品的理想配色方案 date: 2024/3/1 20:47:45 updated: 2024/3/1 20:47:45 tags: 色彩搭配品牌形象用户体验情感连接信息传达视觉层次色调选择 引言 友善的色彩搭配和色调选择是现代产品设计中不可忽视的关键因素。通过正确…

Linux yum安装pgsql出现Bad GPG signature错误

官方文档&#xff1a;https://www.postgresql.org/download/linux/redhat/ sudo yum install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-7-x86_64/pgdg-redhat-repo-latest.noarch.rpm sudo yum install -y postgresql12-server sudo /usr/pgsql-12/bin/…

Rust使用calamine读取excel文件,Rust使用rust_xlsxwriter写入excel文件

Rust使用calamine读取已存在的test.xlsx文件全部数据&#xff0c;还读取指定单元格数据&#xff1b;Rust使用rust_xlsxwriter创建新的output.xlsx文件&#xff0c;并写入数据到指定单元格&#xff0c;然后再保存工作簿。 Cargo.toml main.rs /*rust读取excel文件*/ use cala…

Tomcat 架构

一、Http工作原理 HTTP协议是浏览器与服务器之间的数据传送协议。作为应用层协议&#xff0c;HTTP是基于TCP/IP协议来传递数据的&#xff08;HTML文件、图片、查询结果等&#xff09;&#xff0c;HTTP协议不涉及数据包&#xff08;Packet&#xff09;传输&#xff0c;主要规定了…

本地快速部署谷歌开放模型Gemma教程(基于WasmEdge)

本地快速部署谷歌开放模型Gemma教程&#xff08;基于WasmEdge&#xff09; 一、介绍 Gemma二、部署 Gemma2.1 部署工具2.1 部署步骤 三、构建超轻量级 AI 代理四、总结 一、介绍 Gemma Gemma是一系列轻量级、最先进的开放式模型&#xff0c;采用与创建Gemini模型相同的研究和技…

RuoYi-Vue-Plus功能分析-jackson配置

文章目录 前言一、配置文件二、配置类三、注解四、json工具类1. 工具内容2. 使用工具 前言 前端在给我发送请求的时候一般包含三个部分url&#xff0c;header&#xff0c;body。那么就会涉及我们后端如何接收这些请求参数并且我们处理完毕参数后前端又如何接收参数 通过url传…

代码随想录刷题笔记 DAY 37 | 动态规划理论基础 | 斐波那契数 No.509 | 爬楼梯 No.70 | 使用最小花费爬楼梯 No.746

文章目录 Day 3700. 动态规划理论基础01. 斐波那契数&#xff08;No. 509&#xff09;<1> 题目<2> 笔记<3> 代码 02. 爬楼梯&#xff08;No. 70&#xff09;<1> 题目<2> 笔记<3> 代码 03. 使用最小花费爬楼梯&#xff08;No. 746&#xff…

ECMAScript-262 @2023版本中的关键字和保留字

1、什么是标识符&#xff1f; 所谓标识符&#xff0c;就是javascript里的变量、函数、属性或函数参数的名称&#xff0c;可由一个或多个字符组成&#xff0c;当然标识符有命名规范 标识符第一个字符必须是 一个字母、下划线&#xff08;_&#xff09;或美元符号&#xff08;$…

ONLYOFFICE文档8.0全新发布:私有部署、卓越安全的协同办公解决方案

ONLYOFFICE文档8.0全新发布&#xff1a;私有部署、卓越安全的协同办公解决方案 文章目录 ONLYOFFICE文档8.0全新发布&#xff1a;私有部署、卓越安全的协同办公解决方案摘要&#x1f4d1;引言 &#x1f31f;正文&#x1f4da;一、ONLYOFFICE文档概述 &#x1f4ca;二、ONLYOFFI…

【新书推荐】10.2 分支程序设计

稍微复杂一些的程序通常需要做某种条件判断&#xff0c;然后再决定程序的执行流程。当然也可以无条件跳转到程序的另一处地址开始执行。本节我们将详细介绍分支结构的程序设计方法。 针对功能较为复杂的程序&#xff0c;程序开发有一套标准的流程&#xff0c;我们将10.1节中的五…

计算机网络【网络安全】

计算机网络——网络安全 一、网络安全问题概述 网络安全威胁 网络安全面临两大类威胁&#xff0c;被动攻击和主动攻击 被动攻击 指攻击者从网络上窃听他人的通信内容&#xff0c;通常把这类攻击称为截获。 主动攻击 篡改 攻击者故意篡改网络上传送的报文 恶意程序 拒绝服…

12、窗口看门狗

目录 1、窗口看门狗概述 2、常用寄存器和库函数配置 3、窗口看门狗实验 1、窗口看门狗概述 之所以称为窗口就是因为其喂狗时间是一个有上下限的范围内&#xff08;窗口&#xff09;&#xff0c;你可以通过设定相关寄存器&#xff0c;设定其上限时间&#xff08;下限固定&…

技术栈选型的时候,ruby、go、java、vue、react应该怎么选择?

选择适合项目需求、团队技术背景和偏好、开发速度、性能要求以及可扩展性的技术栈和框架是一个综合考虑的过程&#xff0c;没有一种通用的最佳选择&#xff0c;取决于具体情况。 选择Vue.js或React应该综合考虑项目的需求、团队的技术背景和偏好、生态系统的支持和发展趋势等因…