全国高校计算机能力挑战赛初赛试题全记录

news2024/11/20 18:48:30

今天搞了mini版蓝桥杯比赛,有时间的话,我们每天都会补充15道主观题。废话不多说,开整!!!


2022.10.11

 抽象:在C++中,如果一个类并没有什么实际信息,那么就是一个抽象类

多态:相同名字的函数有不同的功能,这些函数在不同的类中

 

 静态成员函数:类中函数+static,只能访问静态成员变量

友元函数:在类中函数前+friend(全局函数做友元),friend+所属区域(成员函数做友元)或者实现全局函数访问私有类

友元类:子类前+friend,实现类访问私有类

 

 

编译期间是:静态多态 

 

类模板:一个通用类,类中内容可以不确定 

语法:template<class T1,class T2>

函数模板:一个通用函数,函数参数可以不确定

语法:template<typename T>

 

 cin,cout,cerr,clog是预留的流对象

 

二维数组,必须初始化列 

 

判断字符串为空函数:empty,size,length ,compare

 

C:只在复合语句中有效 

 

 

 

 

A,B写反了 

 


2022.12.2不在沉默中爆发,就在沉默中GG,选择题终于迎来了更新,本次内容来源于我网上搜的内容,参考文章为:

(12条消息) c++选择题(选择题)_bless_my_head的博客-CSDN博客_析构函数中不能加代码https://blog.csdn.net/bless_my_head/article/details/107116563


 

 

 ok,我们继续学习选择题吧。

虚函数:加上virtual修饰的类内函数

纯虚函数:虚函数 = 0。

抽象类:具有纯虚函数的类,其纯虚函数的实现由派生类给出

基类:父类

派生类:子类

总结:一个基类如果是抽象类,那么它的派生类可以是抽象类也可以不是,这是根据该派生类是否对纯虚函数进行了声明(不要后面的=0)


公共权限 public ,类内可以访问,类外可以
保护权限 protected ,类内可以访问,类外不行,儿子可以访问父亲保护内容
私有权限 private ,类内可以访问,类外不行,儿子不能访问父亲内容

构造函数:可以有参数,可以重载:先父类再子类

析构函数:不能有参数,不能重载 :先子类再父类

 

 

 

 

前置:add++,后置是 ++add(int) 

执行顺序:1构造A,2调用后A,2构造B,1析构a,2调用a,2析构b

AABaab 

 

有说明,没有实现的类 

string是一个类 

2022.10.28

#include<iostream>

using namespace std;

int main()
{
  int HH, MM, SS, hh, mm, ss;
  long long int ans;
  int h;
  scanf("%d:%d:%d%d:%d:%d",&HH,&MM,&SS,&hh,&mm,&ss);
  h = (hh - HH + 24) % 24;
  h = h * 3600;
  ans = h + mm * 60 - MM * 60 + ss - SS;
  
  cout<< ans<<endl;
  return 0;
  
  
}


2022.11.21

前一阵重庆遇到小🐏人了,emmmm,希望疫情早点结束吧,然后咧,从今天开始这个比赛的文章要开始继续更新了。


这里我参考该博主的文章,按着它的刷题下来,因为他说刷了这个不想拿奖都难!那懂得都懂!

(2条消息) 2021年计算机能力挑战赛真题总结C++版_yyjshang的博客-CSDN博客_计算机能力挑战赛题目https://blog.csdn.net/yyjshang/article/details/121076937废话不多说,开干!!!

1

1.本题理解num数组为一个关键,其实我也说不太清楚了,但是对这写就行

2.for循环采用 -- 操作,这是因为访问输入值的时候,从最低位开始,如果你写 ++ 那么就从高位开始了

3.对于字符串和数字之间转换问题,切记!!!

‘0’->48    '9'->57

'a'->97    'z'->122

'A'->65    'Z'->90

然后本题转换为:

字符串num【i】这一位对应的整型

如果这一位字符串是0-9之间,那么ans = num【i】-47

如果这一位字符串是a-f之间,那么ans = num【i】-87

注意:0-9之间,说明改字符串不超过58,a-f之间,说明改字符串不超过103

#include<iostream>
#include<string>
using namespace std;
int main() {
	string str;
	cin >> str;
	long long temp = 0;
	long long result = 0;
	int i, num[] = { 1, 2, 6, 30, 210, 2310, 30030, 510510, 9699690, 223092870 }, toDec;
	for (i = str.length() - 1; i > -1; --i) {
		toDec = num[str.length() - 1 - i];
		if (str[i] > 47 && str[i] < 58) { //‘0’ == 48 , ‘9’== 57
			temp = str[i] - 48;
			result += temp * toDec;
		}
		else {
			temp = str[i] - 87;  //'a' =97  - 87 = 10;
			result += temp * toDec;
		}
	}

	cout << result;
	return 0;
}

2

1.char类型求长度,按照下面固定方式即可,-1是因为还有一个'\'

int len = (sizeof(s) / sizeof(s[0])) - 1;//获取长度

2.由于在原题找不到题目,所以对于判错是有问题的,比如说这里题目是说给定字符串全是AA这种,不会有1 +这种类型,那么在判定的时候,只需要判断为空即可

#include<iostream>
#include<string>
using namespace std;
int main() {
	char s[10000];
	cin >> s;
	int len = (sizeof(s) / sizeof(s[0])) - 1;//获取长度
	for (int i = 0; i< len; i++) {
        //满足if条件就break,说明不是我要的字符串
		if (s[i] > 'z' || s[i] < 'A' || s[i]>'Z'&& s[i]<'a') break;//跳过空元素
		s[i] = 187 - s[i];
		
	}
	for (int i = 0; i< len; i++) {
		if (s[i] > 'z' || s[i] < 'A'||s[i]>'Z'&& s[i]<'a') break;//跳过空元素
		cout << s[i];
	}
	
	return 0;
}

#include<iostream>
#include<string>
using namespace std;
int main() {
	char s[10000];
	cin >> s;
	int i = 0;
    //直接判断字符串最后一位,不到最后一位就一直替换
	while (s[i] != '\0'){
		s[i] = 187 - s[i];
		i++;
	}
	i = 0;
	while (s[i] != '\0') {
		cout << s[i];
		i++;
	}
	return 0;
}

3

 最简单方法就是利用find函数去按个查找。所以我们先对str2中用substr求得每一个的字符,然后利用find函数查找

#include<iostream>
#include<string>
using namespace std;
int main()
{
	string str1;
	string str2;
	cin >> str1;
	cin >> str2;
	int len1 = str1.length();
	int len2 = str2.length();
	int index = 0;
	for (int i = 0; i < len2; i++) {
		index = str1.find(str2.substr(i, 1));
		if (index == -1) {
			cout << "N";
		}
		else {
			cout << "Y";
		}
	}
	cout << endl;
	return 0;
}

4

质因素很关键,这是最基础的,简单来说就比如,2,3,4,5,6各自质因素为2,3,2x2,5,6。关键就在于理解质因数。

比如说给你2,4求公共质因数,那么2是2,4是2x2,那么公共质因数就是2

比如说给你4,8求公共质因数,那么4是2x2,8是2x2x2,那么公共质因数是2+2=4

比如说给你9,27求公共质因数,那么9是3x3,27是3x3x3,那么公共质因数是3+3=6

因此本题分为如下步骤:

1,遍历两两元素,这个用两个for循环实现

2. 求两个数的公共质因数,首先因为最小公共质因数为2,那么该函数先对两个数从2开始取模看能不能除掉,如果可以,则说明有个2的公共质因数,同时,有些数不仅只有2,还有3的可能,因此这里加了循环。此外还有一点就是得到一个公共质因数之后要把两数除掉该公共质因数,才能继续求下一个

3.最后一步完成相加即可

#include<iostream>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#include <algorithm>
#include<string.h>
#include<set>
#include<math.h>
#define llu unsigned long long
using namespace std;


int yinshu(int x, int y)
{
	if (x < y) swap(x, y);
	for (int i = 2; i <= y; i++)
	{
		if (x % i == 0 && y % i == 0) return i;
	}
	return 1;
}

int a[110];
llu s = 0;


int main()
{

	int n;
	cin >> n;

	for (int i = 0; i < n; i++)
		cin >> a[i];

	for (int i = 0; i < n - 1; i++)
	{
		for (int j = i + 1; j < n; j++)
		{
			int x = a[i], y = a[j];
			while (true)
			{
				int t = yinshu(x, y);
				if (t != 1)
				{
					s = (s + t) % 1000000007;
					x /= t;
					y /= t;
				}
				else break;
			}

		}
	}

	cout << s << endl;

	return 0;
}

1.为什么对h取模关键在于,加入当前10:50:10,经过20分钟后是11:10:10.那么计算的时候先得出11-10=1h,但其实只有20分钟,那么在减去50分钟,加上10分钟,刚好就是20分钟。这就是本题的关键。

2.试题中用scanf,vistudio用scanf_s

#include<iostream>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#include <algorithm>
#include<string.h>
#include<math.h>
#define llu unsigned long long
using namespace std;



int main()
{

	int hh1, mm1, ss1, hh2, mm2, ss2;
	scanf_s("%d:%d:%d%d:%d:%d", &hh1, &mm1, &ss1, &hh2, &mm2, &ss2);
	long long int h,m;
	h = (hh2 - hh1 + 24) % 24;
	h *= 3600;

	h = h + mm2 * 60 + ss2 - mm1 * 60 - ss1;


	cout << h << endl;


	return 0;
}

 1.对给定的秒数进行判断可以分成多少个小时,分钟和秒,然后把结果加上

2.需要注意,每次确定完分配多少小时之后是需要减去分配时间的

3.最后的输出要进行取模以及保留两位小数

#include<iostream>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#include <algorithm>
#include<string.h>
#include<math.h>
#define llu unsigned long long
using namespace std;



int main()
{
	int hh, mm, ss, second;
	scanf_s("%d:%d:%d", &hh, &mm, &ss);
	scanf_s("%d", &second);

	int h = second / (60 * 60);//求出有几小时
	int m,s;
	int temp1, temp2;
	if (h != 0) {
		//说明有小时,那么减去该小时
	    temp1 = second - h * 60 * 60;
		m = temp1 / 60;//求出多少分钟
	}
	else {
		temp1 = second;
		m = second / 60;//求出多少分钟
	}
	if (m != 0) {
		//说明有分钟,那么减去该分钟
		temp2 = temp1 - m * 60 ;
		s = temp2 % 60;//求出多少miao
	}
	else {
		s = second % 60;//求出多少miao
	}
	hh += h;
	hh %= 24;
	mm += m;
	mm %= 60;
	ss += s;
	printf("%02d:%02d:%02d", hh, mm, ss);

	return 0;
}

 1.这次终于用c++写法了,实现两行输入这种

2.注意求公因数的方法,辗转相除法,建议去搜一下

#include<iostream>
#include<vector>
using namespace std;

using ll = long long;

inline ll gys(ll a, ll b) {
	int temp;
	if (a < b) {
		swap(a, b);
	}
	while (b != 0) {//最大公约数用辗转相除法
		temp = a % b;
		a = b;
		b = temp;
	}
	return a;
}
inline ll gbs(ll a, ll b) {//两个数的乘积等于这两个数的最大公约数与最小公倍数的积

	return a * b / gys(a, b);
}

int main()
{
	int N;
	int n;
	vector<int>vec;
	cin >> N;
	for (int i = 0; i < N; i++) {
		cin >> n;
		vec.push_back(n);
	}
	//完成输入,现在遍历vec
	ll result = 0;
	for (int i = 0; i < vec.size() - 1; i++) {
		for (int j = i + 1; j < vec.size(); j++) {
			result += gbs(vec[i], vec[j]);
			result %= 1000000007;
		}
	}
	cout << result;
	return 0;
}

到这里,我对这个比赛很气!!!真的,它这个测试系统以及题目,各自牛头不对马嘴!很难受,想着天下一家亲原则,我选择开始直接刷蓝桥杯的题目了,只是后续适应一下一些规则就ok。

2022.11.30


我们现在不从题目入手,而是更多偏向写法开始。

输入整型

int N;
int num;
cin>>N;
for(int i = 0; i < N; i++){
    cin>>num;
    vec.push_back(num);
    //或者用数组
    a[i] = num;
}

输出浮点型,以及固定字符串

注意头文件
#include<algorithm>
#include <iomanip>
 float ans2 = 100.0 * num / N;//num是int
  cout<<setiosflags(ios::fixed)<<setprecision(0)<<ans1<<"%"<<endl;
    //(0)表示保留0个小数

平闰年判断

bool isLeap(int y){
    return (y%4==0&&y%100!=0)||(y%400==0);
}

回文串判断及输出

#include<bits/stdc++.h>
using namespace std;
long long n,x;
bool hws(long long n)
{
	long long ans=0,m=n;
	while(m>0)
	{
		ans=ans*10+m%10;
		m/=10;
	}
	x=ans;
	return ans==n;
}
int main()
{ 	
  	cin>>n;
  	if(hws(n)) cout<<"Yes";
  	else cout<<x;
	return 0;
}

字符串查找,插入,删除

其中,查找下标从0开始,后面两个从1开始

int main()
{
    string str;
    int N;
    int first, second;
    string ch;
    cin >> str;
    cin >> N;
    cin >> ch;
    for (int i = 0; i < N; i++) {
        cin >> first >> second;
        int pos = str.find(ch, first-1);
        if (pos <= second - 1 && pos >= first - 1) {
            str.erase(pos , 1);
        }
        else {
            str.insert(second , ch);
        }
    }
    cout << str;
    return 0;
}

vector插入字符串,以及复制vector,删除vector元素

vec.push_back(char(str[j]));   其中str是字符串,对于str[j]这是一个asiic码,通过char进行转换为char后插入的就是字母,或者to_string转为字符串。注意插入要根据vector类型

vec1.assign(vec.begin(), vec.end());


vec.clear();

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

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

相关文章

基于java+springboot+mybatis+vue+mysql的招生管理系统

项目介绍 招生管理系统采用java技术&#xff0c;基于springboot框架&#xff0c;vue技术&#xff0c;mysql数据库进行开发。本系统主要包括管理员和学生两个角色组成&#xff0c;主要包括以下功能&#xff1a; &#xff08;1&#xff09;前台&#xff1a;首页、专业信息、招生…

Online DDL和Cardinality

Online DDL和Cardinality前言Fast Index CreationOnline Schema ChangeOnline DDLCardinality什么是CardinalityCardinality是如何进行统计的前言 本文来聊聊关于Mysql索引管理方面的一些内容&#xff0c;首先我们先准备一张表: CREATE DATABASE IF NOT EXISTS test;USE test…

JVM,你是不是过分了?

以我的经验加上和同行们的交流&#xff0c;我认为学 JVM 最好的方法是&#xff1a; 在程序员不同的水平段&#xff0c;做精准的学习。 所谓的精准学习&#xff0c;就是学习对自己工作有巨大帮助的知识点。以工作内容带动学习&#xff0c;等到积累多了&#xff0c;再一举攻克所…

D-027 SerDes详解

SerDes详解1 SerDes简介1.1 并行总线接口1.2 SerDes接口1.3 SerDes的特点2 发送均衡技术1 SerDes简介 1.1 并行总线接口 在SerDes流行之前&#xff0c;芯片之间的互联时通过系统同步或者源同步的并行接口进行接口传输数据。 并行接口定义图片系统同步发送端和接收端都是由系…

影驰H610MK主板在MBR硬盘上安装系统(可用于安装WIN7)

记录一次MBR格式的机械硬盘安装WIN10系统。 一、进入BIOS界面 二、设置BIOS界面 1、设置系统模式&#xff1a;高级->系统模式选择&#xff0c;选择Legacy and UEFI &#xff08;默认模式为UEFI&#xff09; 2、设置CSM配置 1&#xff09;、进入CMS配置界面&#xff1a;高级…

Js实现简单的文件类型、文件大小、图片像素校验

文章目录1、简单的小Demo2、更多说明2.1 利用循环判断DOM是否渲染完成2.2 利用MutationObserver监听DOM树变化2.3 关于节点的宽高属性2.4 关于页面的宽高属性2.5 关于FileReader提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 1、简单的小Demo <!DO…

“互联网+”时代保险公司经营管理模式研究

目 录 摘 要 3 引言 4 一、公司经营管理模式的理论概述 5 &#xff08;一&#xff09;“互联网”的概念 5 &#xff08;二&#xff09;企业经营管理的主要模式 5 二、众安保险公司的基本情况 6 三、众安公司经营管理模式面临的困难 8 &#xff08;一&#xff09;经营管理方式滞…

关于SpringBoot集成ES Scroll API(滚动查询)的实践

待到秋来九月八&#xff0c;我花开后百花杀背景&#xff1a;大胆尝试实践&#xff1a;学习踩坑最终解决背景&#xff1a; 那是年初在某个交付项目&#xff0c;从用户侧获知了一个elastic search作为分布式数据库的一个瓶颈&#xff0c;那就是单次查询量超过了ES的默认单次查询…

DirectX12 - Pipeline(管线)之IA

这里是SunshineBooming&#xff0c;GPU公司一枚小小的Driver工程师&#xff0c;主要工作是写DirectX12 Driver&#xff0c;我会持续更新这个DX12 Spec系列&#xff0c;可能比较冷门&#xff0c;但是都是干货和工作中的心得体会&#xff0c;有任何GPU相关的问题都可以在评论区互…

原来服务端的退出姿势也可以这么优雅

最简单的 http 服务端 咱们来写一个简单的 http 服务器 func main() { srvMux : http.NewServeMux() srvMux.HandleFunc("/getinfo", getinfo) http.ListenAndServe(":9090", srvMux)}func getinfo(w http.ResponseWriter, r *http.Request) { fmt.Printl…

程序猿入门|编程注重写注释,代码规范注释有哪些讲究?

注释风格 1.总述 一般使用 // 或 /* */,只要统一就好。 2.说明 // 或 /* */ 都可以,但 // 更 常用,要在如何注释及注释风格上确保统一。 文件注释 1.总述 在每一个文件开头加入版权、作者、时间等描述。 文件注释描述了该文件的内容,如果一个文件只声明,或实现,或测试…

JVM运行时参数

3.类型三&#xff1a;-XX参数选项 特点 作用 用于开发和调试jvm 分类 特别地 二、添加jvm参数选项 1.运行jar包 2.通过Tomcat运行war包 3.程序运行过程中 三、常用的JVM参数选项 1.打印设置的XX选项及值 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20210219105124…

window安装torch环境--不踩坑须知!

window安装torch环境–不踩坑须知&#xff01; 1. 查看电脑安装的cudn版本 进入cmd输入&#xff1a; nvidia-smi2.查找cuda对应的torch版本 在官网查找&#xff1a;https://pytorch.org/get-started/previous-versions/ 如果呢你在新建的conda环境里输入该命令&#xff0c;…

Java基于JSP的网络音乐KTV点歌电台网站

随着我国网民的增加,也促进了网络音乐电台的开发。随着网络技术的发展,人们在利用网络学习的同时,也在享受着网络带来的各种附带产品所产生的效应,如网络游戏,网络歌曲。网络音乐电台正是在这样的需求前提下应运而生,给人们的日常生活带来了极大的乐趣,让人们在繁忙疲惫的工作之…

TensorRT从理论到实践

TensorRT理论 一. TensorRT介绍 TensorRT是一个高性能的深度学习推理优化器&#xff0c;可以为深度学习应用提供低延迟、高吞吐率的部署推理。TensorRT可用于对超大规模数据中心、嵌入式平台或自动驾驶平台进行推理加速。TensorRT现已能支持Tensorflow、Caffe、Mxnet、Pytorc…

《嵌入式基础》实验三 ARM编程模型和ARM指令

零、前言 本人不擅长写汇编相关的东西&#xff0c;所以以下内容也是不断摸索&#xff08;百度 &#xff09; 整出来的&#xff0c;和linux的实验报告的质量相比较低。 一、 实验目的 掌握ARM微处理器的汇编指令的使用方法。掌握使用 LDM/STM&#xff0c;B&#xff0c;BL 等指…

Struts、Struts2、Spring MVC、JSF、AngularJS、React以及Vue的对比

Struts是一种Java语言的Web应用框架&#xff0c;用于构建基于Java的Web应用程序。它旨在为开发人员提供一种简单易用的方法来构建动态Web页面。Struts框架提供了一组组件&#xff0c;用于处理常见的Web应用程序任务&#xff0c;包括处理用户输入&#xff0c;验证用户输入&#…

(算法设计与分析)第七章随机化算法概述

文章目录一&#xff1a;概述&#xff08;1&#xff09;什么是随机化算法&#xff08;2&#xff09;随机化算法的特点&#xff08;3&#xff09;随机化算法分类&#xff08;4&#xff09;随机数二&#xff1a;数值随机化算法&#xff08;以计算πππ值为例&#xff09;三&#…

分布式计算 MapReduce 究竟是怎么一回事?

前言 如果要对文件中的内容进行统计&#xff0c;大家觉得怎么做呢&#xff1f;一般的思路都是将不同地方的文件数据读取到内存中&#xff0c;最后集中进行统计。如果数据量少还好&#xff0c;但是面对海量数据、大数据的场景这样真的合适吗&#xff1f;不合适的话&#xff0c;…

操作系统装完之后,安装几个特别有用的经典软件,都是电脑必备,包含pdf编辑、图片编辑、wiki、压缩、影音等等

操作系统装完之后&#xff0c;安装几个特别有用的经典软件&#xff0c;都是电脑必备&#xff0c;包含pdf编辑、图片编辑、wiki、压缩、影音等等。 Gimp https://www.gimp.org/ Gimp 是一款小巧实用的图片编辑工具。 如果你不想用笨重的PS&#xff0c;那可以尝试一下Gimp&…