蓝桥杯第十六届模拟赛——基础细节考频分析
文章目录
- 前言
- 一、STL函数
- 二、日期问题
- 三、质数与约数
- 四、基本常识
- 总结
前言
一、STL函数
- #include< cmath >
详解floor函数、ceil函数和round函数
1.floor()
功能:把一个小数向下取整如果数是2.2 ,那向下取整的结果就为2.000000如果数是-2.2 ,那向下取整的结果就为-3.000000
原型:double floor(doube x);
返回值:成功:返回一个double类型的数,此数默认有6位小数无失败的返回值注:带有强制转化功能,但与int(sqrt(n))有区别
sqrt()意思是平方根函数,计算一个非负实数的平方根。
floor对正负参数皆是向下取整,而强制转化是向零取整。2.ceil()
功能:把一个小数向上取整如果数是2.2 ,那向上取整的结果就为3.000000如果数是-2.2 ,那向下取整的结果就为-2.000000
原型:double ceil(doube x);
返回值:成功:返回一个double类型的数,此数默认有6位小数无失败的返回值3.round()
功能:把一个小数四舍五入即就是如果数是2.2 ,那四舍五入的结果就为2如果数是2.5,那结果就是3
原型:double round(doube x);4.返回类型时输入/输出
区分 %d, %ld, %lld, %lf, %f 等
%d:用于 int %ld:用于 long %lld:用于 longlong
输入时:float 输入用 %f double 输入用 %lf
输出时:float, double都用 %f 输出就行了(在C89/C90环境下,double 用 %lf 会出错)
- #include< string >
细解常用函数
1. 构造函数string s2("Hello World"); // 字符串初始化为 "Hello World" string s3(s2); //拷贝构造: 将s2复制给s3、 输出为: Hello Worldstring s4(s2, 2, 3); // 从 s2 的下标 2 的位置开始复制 3 个值给 s4,输出为: llostring s5(s2, 3); // 从 s2 的下标 3 的位置开始复制到结尾个字符给s5//输出为: llo Worldstring s6(5, '#'); // 生成5个字符为 # 的字符串,输出为: #####2. compare: 字符串大小比较(字典序比较)原理: 两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇 '\0’为止。例如:aaa < ab; a < b; baa < bbc;string s1("abcd"); string s2("aBcd");// s1 与 s2 相比第二个字符 b 的ASCII值大于 Bcout << s1.compare(s2) << endl; // s1 > s2 所以输出13. getline:getline(cin, str) 获取一行字符串// cin 输入时默认空格是作为结束分隔,所以可以用getline将空格输入字符串中string s4; getline(cin, s4);cout << "s4: " << s4 << endl; //输入:hh nn ll! 输出 hh mm LL!4. find / rfind:string s3("Youth gives you light please don't let it down");int pos = s3.find(' '); int rpos = s3.rfind(' '); // 5 415. substr:string s4("Hello World!");// 当substr给两个参数时主要功能为复制子字符串,从下标 n 开始,复制 m 个字符string s5 = s4.substr(3, 5); // 输出为: lo Wo// 当substr不给参数时就为直接拷贝构造string s6 = s4.substr(); // 输出为: Hello World!// 当只给定左参数时,就从 n 开始复制到结尾string s7 = s4.substr(3); // 输出为: lo World!
二、日期问题
//求日期问题的模板
int days[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};bool check_valid(int year, int month, int day)
{if (month == 0 || month > 12) return false;if (day == 0) return false;if (month != 2){if (day > days[month]) return false;} //一定要打大括号,不然第二个if会与else呼应else{int leap = ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0));if (day > days[month] + leap) return false;}return true;
}
三、质数与约数
- 如何快速判断质数
bool is_Prime(int n){if(n <= 1) return false;if(n <= 3) return true;if(n % 2 == 0 || n % 3 == 0) return false;//只需检查6k±1的数是否满足行了for(int i = 5; i * i <= n; i += 6){if(n % i == 0 || n % (i + 2) == 0) return false;}return true;
}
- 如何求约数
- 先求出两个数的最大公约数gcd:
int gcd(int a, int b) return b ? gcd(b, a%b) : a; - 找出gcd的所有约数, 采用
质因数分解法
- 先求出两个数的最大公约数gcd:
#include <iostream>
#include <vector>
#include <map>
using namespace std;// 质因数分解函数
map<int, int> prime_factors(int n) {map<int, int> factors;for (int i = 2; i * i <= n; ++i) {while (n % i == 0) {factors[i]++;n /= i;}}if (n > 1) factors[n]++;return factors;
}// 生成所有约数
vector<int> get_divisors(int n) {map<int, int> factors = prime_factors(n);vector<int> divisors = {1};for (auto [p, exp] : factors) {int curr_size = divisors.size();int p_power = 1;for (int e = 1; e <= exp; ++e) {p_power *= p;for (int i = 0; i < curr_size; ++i) {divisors.push_back(divisors[i] * p_power);}}}return divisors;
}// 计算GCD(欧几里得算法)
int gcd(int a, int b) {return b == 0 ? a : gcd(b, a % b);
}int main() {int a = 24, b = 36;int d = gcd(a, b); // 计算GCDvector<int> common_divisors = get_divisors(d); // 获取所有公约数cout << "GCD(" << a << ", " << b << ") = " << d << endl;cout << "所有公约数:";for (int x : common_divisors) cout << x << " ";return 0;
}
- 如何求最大质约数
#include <bits/stdc++.h>
using namespace std;
int main()
{int ans = 0;int n = 2024;for (int i = 2; i * i <= n; i++){if (n % i == 0){ans = i;while (n % i == 0) n /= i;}}if (n > 1) ans = n;cout << ans;
}
四、基本常识
-
常见进制表示法
前缀:
0b:二进制表示法。例如,0b1101 表示二进制数 1101。
0o:八进制表示法。例如,0o57 表示八进制数 57。
0x:十六进制表示法。例如,0x1A 表示十六进制数 1A。
后缀:
b 或 B:二进制表示法。例如,101b 或 101B 表示二进制数 101。
o 或 O:八进制表示法。例如,75o 或 75O 表示八进制数 75。
x 或 X:十六进制表示法。例如,1E2x 或 1E2X 表示十六进制数 1E2。 -
常用进制转化法
#include<iostream>
using namespace std;
int s[N];
int main()
{int R, n; //表示R进制,该转化皆以十进制为中转站int count = 0;cout << "请输入要转化的进制:" << endl;cin >> n;cout << "请输入转化成的进制:" << endl;cin >> R;while (n){s[++count] = n % R;n = n / R;}for (; count > 0; count--) cout << s[count];return 0;
}
-
字符串转换为数字(头文件< string >)
1.stoi():将字符串转换为整型string s = "123"; int n = stoi(s);
2.stoll():将字符串转换为long long
3.stof():将字符串转换为float型
4.stod():将字符串转换为double型以上同理可得 -
memset用法及注意事项
void* memset(void* ptr, int value, size_t num);ptr:指向要填充的内存区域的指针。
value:要设置的值(以 int 形式传递,但实际是按字节填充)。
num:要填充的字节数。
value 参数是 1:
memset(b, 1, sizeof b)会将 b 的每一个字节(byte)设置为 1。
注意:1 是一个字节值,而不是整数 1。sizeof b:这是 b 的总字节大小。int 类型的存储方式:
在大多数系统中,int 类型占 4 个字节。
例如,int 值为 1 的二进制表示为:00000000 00000000 00000000 00000001。
但是memset 会将 b 的每一个字节设置为 1,而不是将每个 int 设置为 1。
因此,每个 int 的 4 个字节都会被设置为 1,即 00000001 00000001 00000001 00000001。
这个二进制值对应的十进制数是 16843009(即 0x01010101)。
结果:数组 b 中的每个 int 元素都会被设置为16843009,而不是 1。 -
对于长度为
k的素数等差数列,其公差d必须被所有小于 k 的素数整除
例如,当 k=5,公差应为 6 的倍数;当 k=7,公差应为 30 的倍数。用户示例中的 210 对应更大的 k,如 k = 11。
总结
注意细节问题,往往不注意细节会产生不必要的异常
相关文章:
蓝桥杯第十六届模拟赛——基础细节考频分析
文章目录 前言一、STL函数二、日期问题三、质数与约数四、基本常识总结 前言 一、STL函数 #include< cmath > 详解floor函数、ceil函数和round函数 1.floor() 功能:把一个小数向下取整如果数是2.2 ,那向下取整的结果就为2.000000如果数是-2.2 &…...
【C++初阶】----模板初阶
1.泛型函数 泛型编程:编写与类型无关的通用代码,是代码复用的一种手段。模板是泛型编程的基础。 2.函数模板 2.1函数模板的概念 函数模板代表了一个函数家族,该函数模板与类型无关,在使用时被参数化,根据实参类型…...
PyCharm操作基础指南
一、安装与配置 1. 版本选择 专业版:支持 Web 开发(Django/Flask)、数据库工具、科学计算等(需付费)。 社区版:免费,适合纯 Python 开发。 2. 安装步骤 访问 JetBrains 官网 下载对应版本。…...
Pycharm(七):几个简单案例
一.剪刀石头布 需求:和电脑玩剪刀石头布游戏 考察点:1.随机数;2.判断语句 import random # numrandom.randint(1,3) # print(num) # print(**30) #1.录入玩家手势 playerint(input(请输入手势:(1.剪刀 2.石头 3&…...
Android并发编程:线程池与协程的核心区别与最佳实践指南
1. 基本概念对比 特性 线程池 (ThreadPool) 协程 (Coroutine) 本质 Java线程管理机制 Kotlin轻量级并发框架 最小执行单元 线程(Thread) 协程(Coroutine) 创建开销 较高(需分配系统线程资源) 极低(用户态调度) 并发模型 基于线程的抢占式调度 基于协程的协作式调度 2. 核心差异…...
MySQL内存使用率高问题排查与解决方案:
目录标题 **一、问题现象****二、核心排查步骤****1. 参数检查****2. 内存使用分析****3. 存储过程/函数/视图检查****4. 操作系统级检查** **三、解决方案****1. 调整MySQL配置****2. 关闭透明大页(THP)****3. 优化查询与存储过程****4. 硬件与环境优化…...
gnvm切换node版本号
1. gnvm下载官网 GNVM - Node.js version manager on Windows by Go 2. 安装 2.1 不存在 Node.js 环境 下载并解压缩 gnvm.exe 保存到任意文件夹,并将此文件夹加入到环境变量 Path。 2.2 存在 Node.js 环境 下载并解压缩 gnvm.exe 保存到 Node.js 所在的文件夹。 2.…...
PyTorch 深度学习实战(29):目标检测与 YOLOv12 实战
在上一篇文章中,我们探讨了对比学习与自监督表示学习。本文将深入计算机视觉的核心任务之一——目标检测,重点介绍最新的 YOLOv12 (You Only Look Once v12) 算法。我们将使用 PyTorch 实现 YOLOv12 模型,并在 COCO 数据集上进行训练和评估。…...
Python爬虫:开启数据抓取的奇幻之旅(一)
目录 一、爬虫初印象:揭开神秘面纱 二、工欲善其事:前期准备 (一)Python 环境搭建 1.下载 Python 安装包: 2.运行安装程序: 3.配置环境变量(若自动添加失败)&#x…...
python下载m3u8格式视频
一、安装 m3u8库 pip install requests pip install requests m3u8 二、编码实现 import os import re import requests import subprocess# 下载ts文件 def down_ts_file(base_url, m3u8_url, download_dir):# 从m3u8文件中获取所有ts的分片名称信息response requests.get…...
【区块链安全 | 第五篇】DeFi概念详解
文章目录 DeFi1. DeFi 生态概览2. 去中心化交易所(DEX)2.1 AMM(自动做市商)模型2.2 订单簿模式(现货交易) 3. 借贷协议3.1 Aave3.2 使用闪电贷(Flash Loan) 4. 稳定币(St…...
【初探数据结构】归并排序与计数排序的序曲
💬 欢迎讨论:在阅读过程中有任何疑问,欢迎在评论区留言,我们一起交流学习! 👍 点赞、收藏与分享:如果你觉得这篇文章对你有帮助,记得点赞、收藏,并分享给更多对数据结构感…...
基于ruoyi快速开发平台搭建----超市仓库管理(修改记录1)
一、数据库的设计一定注意不要用关键字 数据库是同学设计的,但是在实践过程中,发现,生成的代码一直报错,结果发现数据库里面商品表里面的商品类别竟然设置成class, 注意:: class 是 Java 中的关键字&…...
《AI加持,SQL Server预测性维护全攻略》
在数字化时代,数据就是企业的生命线,而SQL Server作为一款应用广泛的关系型数据库管理系统,承载着企业海量的数据资产。但数据库运行过程中,故障就像隐藏在暗处的“定时炸弹”,随时可能引发数据丢失、业务中断等严重后…...
Java基础——面向对象
1.抽象Abstract:抽象类和抽象方法; 抽象类:不完整的类,就是抽象类:abstract class 类名; 抽象方法:只有声明,没有实现的方法; abstract 返回值类型 方法名(参数&#…...
Springboot学习笔记3.20
目录 1.实战篇第一课 我们将会在本次实战中学习到哪些知识点? 开发模式和环境搭建: 注册接口 1.Lombok 2.开发流程 1.controller层,这个层会指明访问路径和要执行的逻辑: 2.我们把返回结果根据接口文档包装成一个类result&a…...
Ubuntu和Windows实现文件互传
1.开启Ubuntu下的FTP服务: (1)终端输入: sudo apt-get install vsftpd(2)安装完成后: 终端输入: /etc 是 Linux 系统的全局配置文件目录,存储系统和应用程序的配置信息…...
java面向对象从入门到入土
面向对象进阶 (写程序的套路) 面向:拿,找 对象:能干活的东西 面向对象编程:拿东西过来做对应的事情 (写程序的套路) 面向:拿,找 对象:能干活的东西 面向对象编程:拿东西过来做对应的事情 重点学习:学习已有对象并使用,学习如何自己设计对象并使用 设计对…...
linux ACL权限控制之用户权限控制程序设计
linux中的ACL(Access Control List,访问控制列表)是一种比传统UNIX权限更细粒度的权限控制机制,允许为文件和目录设置更为具体的用户和组权限。本文介绍使用acl命令和程序api对文件进行更精细的用户权限控制。 1. 命令行示例 使…...
Java多线程与JConsole实践:从线程状态到性能优化!!!
目录 一、前言二、JConsole 使用教程二、线程的基本状态2.1新建状态(New)2.2就绪状态(Ready)2.3运行状态(Running)2.4 阻塞状态(Blocked)2.5. 等待状态(Waitingÿ…...
从入门到精通:SQL注入防御与攻防实战——红队如何突破,蓝队如何应对!
引言:为什么SQL注入攻击依然如此强大? SQL注入(SQL Injection)是最古老且最常见的Web应用漏洞之一。尽管很多公司和组织都已经采取了WAF、防火墙、数据库隔离等防护措施,但SQL注入依然在许多情况下能够突破防线&#…...
Stable Diffusion vue本地api接口对接,模型切换, ai功能集成开源项目 ollama-chat-ui-vue
1.开启Stable Diffusion的api服务 编辑webui-user.bat 添加 –api 开启api服务,然后保存启动就可以了 2.api 文档地址 http://127.0.0.1:7860/docs3. 文生图 接口 地址 /sdapi/v1/txt2img //post 请求入参 {enable_hr: false, // 开启高清hrdenoising_stre…...
缓存使用纪要
一、本地缓存:Caffeine 1、简介 Caffeine是一种高性能、高命中率、内存占用低的本地缓存库,简单来说它是 Guava Cache 的优化加强版,是当下最流行、最佳(最优)缓存框架。 Spring5 即将放弃掉 Guava Cache 作为缓存机…...
第十四届蓝桥杯真题(PWM输出)
一.LED 先配置LED的八个引脚为GPIO_OutPut,锁存器PD2也是,然后都设置为起始高电平,生成代码时还要去解决引脚冲突问题 二.按键 按键配置,由原理图按键所对引脚要GPIO_Input 生成代码,在文件夹中添加code文件夹&#…...
【Qt】ffmpeg编码—存储(H264)
目录 一、编码分析 1.解码线程: 编辑2.编码线程: 编辑 编辑 二、ffmpeg编码 1.注册所有组件 2.编码初始化函数 (2)打开视频流 4.查找编码器 5. 写文件头信息,写到formatContex中 6.发送一帧数据给编码器…...
Webview详解(下)
第三阶段:性能优化 加载速度优化 缓存策略 缓存策略可以显著减少网络请求,提升页面加载速度。常用的缓存策略包括 HTTP 缓存和本地资源预加载。 1. HTTP 缓存 HTTP 缓存利用 HTTP 协议中的缓存机制(如 Cache-Control、ETag 等࿰…...
【MySQL基础-16】MySQL DELETE语句:深入理解与应用实践
1. DELETE语句基础:数据删除的艺术 在数据库管理中,DELETE语句是维护数据完整性和清理过期信息的关键工具。与日常生活中的"删除"不同,数据库中的删除操作需要更加谨慎和精确,因为数据一旦删除,恢复可能非常…...
相对位置嵌入和旋转位置编码
1. 相对位置嵌入:给注意力机制加“人际关系记忆” 像班级座位表 想象全班同学(序列的各个元素)坐成一个圈,老师(模型)要记住每个人之间的相对位置: 传统方法:老师给每个座位贴绝对…...
Unity编辑器功能及拓展(1) —特殊的Editor文件夹
Unity中的Editor文件夹是一个具有特殊用途的目录,主要用于存放与编辑器扩展功能相关的脚本和资源。 一.纠缠不清的UnityEditor 我们Unity中进行游戏构建时,我们经常遇到关于UnityEditor相关命名空间丢失的报错,这时候,只得将报错…...
REC一些操作解法
一.Linux命令长度突破 1.源码如下 <?php $param $_REQUEST[param];if ( strlen($param) < 8 ) {echo shell_exec($param); } 2.源码分析 echo执行函数,$_REQUEST可以接post、get、cookie传参 3.破题思路 源码中对参数长度做了限制,小于8位&a…...
