蓝桥杯第十六届模拟赛——基础细节考频分析

news2025/4/1 23:44:30

文章目录

  • 前言
  • 一、STL函数
  • 二、日期问题
  • 三、质数与约数
  • 四、基本常识
  • 总结


前言

一、STL函数

  1. #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 会出错)
  1. #include< string >
    细解常用函数
1. 构造函数
    string s2("Hello World");  // 字符串初始化为 "Hello World" 
	string s3(s2);			   //拷贝构造: 将s2复制给s3、  输出为: Hello World
	string s4(s2, 2, 3);	   // 从 s2 的下标 2 的位置开始复制 3 个值给 s4,输出为: llo
	string s5(s2, 3);		   // 从 s2 的下标 3 的位置开始复制到结尾个字符给s5
	//输出为: llo World
	string s6(5, '#');			// 生成5个字符为 # 的字符串,输出为: #####

2. compare: 字符串大小比较(字典序比较)
   原理: 两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇 '\0’为止。
   例如:aaa < ab; a < b; baa < bbc;
   string s1("abcd");  string s2("aBcd");
   // s1 与 s2 相比第二个字符 b 的ASCII值大于 B
   cout << s1.compare(s2) << endl; // s1 > s2 所以输出1

3. 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 41

5. 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;
}

三、质数与约数

  1. 如何快速判断质数
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;
}  
  1. 如何求约数
    1. 先求出两个数的最大公约数gcd: int gcd(int a, int b) return b ? gcd(b, a%b) : a;
    2. 找出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); // 计算GCD
    vector<int> common_divisors = get_divisors(d); // 获取所有公约数
    
    cout << "GCD(" << a << ", " << b << ") = " << d << endl;
    cout << "所有公约数:";
    for (int x : common_divisors) cout << x << " ";
    return 0;
}
  1. 如何求最大质约数
#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;
}

四、基本常识

  1. 常见进制表示法
    前缀:
    0b:二进制表示法。例如,0b1101 表示二进制数 1101。
    0o:八进制表示法。例如,0o57 表示八进制数 57。
    0x:十六进制表示法。例如,0x1A 表示十六进制数 1A。
    后缀:
    b 或 B:二进制表示法。例如,101b 或 101B 表示二进制数 101。
    o 或 O:八进制表示法。例如,75o 或 75O 表示八进制数 75。
    x 或 X:十六进制表示法。例如,1E2x 或 1E2X 表示十六进制数 1E2。

  2. 常用进制转化法

#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;
}
  1. 字符串转换为数字(头文件< string >)
    1.stoi():将字符串转换为整型 string s = "123"; int n = stoi(s);
    2.stoll():将字符串转换为long long
    3.stof():将字符串转换为float型
    4.stod():将字符串转换为double型 以上同理可得

  2. 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。

  3. 对于长度为 k 的素数等差数列,其公差 d 必须被所有小于 k 的素数整除
    例如,当 k=5,公差应为 6 的倍数;当 k=7,公差应为 30 的倍数。用户示例中的 210 对应更大的 k,如 k = 11。

总结

注意细节问题,往往不注意细节会产生不必要的异常

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

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

相关文章

【C++初阶】----模板初阶

1.泛型函数 泛型编程&#xff1a;编写与类型无关的通用代码&#xff0c;是代码复用的一种手段。模板是泛型编程的基础。 2.函数模板 2.1函数模板的概念 函数模板代表了一个函数家族&#xff0c;该函数模板与类型无关&#xff0c;在使用时被参数化&#xff0c;根据实参类型…

Pycharm(七):几个简单案例

一.剪刀石头布 需求&#xff1a;和电脑玩剪刀石头布游戏 考察点&#xff1a;1.随机数&#xff1b;2.判断语句 import random # numrandom.randint(1,3) # print(num) # print(**30) #1.录入玩家手势 playerint(input(请输入手势&#xff1a;&#xff08;1.剪刀 2.石头 3&…

gnvm切换node版本号

1. gnvm下载官网 GNVM - Node.js version manager on Windows by Go 2. 安装 2.1 不存在 Node.js 环境 下载并解压缩 gnvm.exe 保存到任意文件夹&#xff0c;并将此文件夹加入到环境变量 Path。 2.2 存在 Node.js 环境 下载并解压缩 gnvm.exe 保存到 Node.js 所在的文件夹。 2.…

PyTorch 深度学习实战(29):目标检测与 YOLOv12 实战

在上一篇文章中&#xff0c;我们探讨了对比学习与自监督表示学习。本文将深入计算机视觉的核心任务之一——目标检测&#xff0c;重点介绍最新的 YOLOv12 (You Only Look Once v12) 算法。我们将使用 PyTorch 实现 YOLOv12 模型&#xff0c;并在 COCO 数据集上进行训练和评估。…

【区块链安全 | 第五篇】DeFi概念详解

文章目录 DeFi1. DeFi 生态概览2. 去中心化交易所&#xff08;DEX&#xff09;2.1 AMM&#xff08;自动做市商&#xff09;模型2.2 订单簿模式&#xff08;现货交易&#xff09; 3. 借贷协议3.1 Aave3.2 使用闪电贷&#xff08;Flash Loan&#xff09; 4. 稳定币&#xff08;St…

【初探数据结构】归并排序与计数排序的序曲

&#x1f4ac; 欢迎讨论&#xff1a;在阅读过程中有任何疑问&#xff0c;欢迎在评论区留言&#xff0c;我们一起交流学习&#xff01; &#x1f44d; 点赞、收藏与分享&#xff1a;如果你觉得这篇文章对你有帮助&#xff0c;记得点赞、收藏&#xff0c;并分享给更多对数据结构感…

基于ruoyi快速开发平台搭建----超市仓库管理(修改记录1)

一、数据库的设计一定注意不要用关键字 数据库是同学设计的&#xff0c;但是在实践过程中&#xff0c;发现&#xff0c;生成的代码一直报错&#xff0c;结果发现数据库里面商品表里面的商品类别竟然设置成class, 注意&#xff1a;&#xff1a; class 是 Java 中的关键字&…

Springboot学习笔记3.20

目录 1.实战篇第一课 我们将会在本次实战中学习到哪些知识点&#xff1f; 开发模式和环境搭建&#xff1a; 注册接口 1.Lombok 2.开发流程 1.controller层&#xff0c;这个层会指明访问路径和要执行的逻辑&#xff1a; 2.我们把返回结果根据接口文档包装成一个类result&a…

Ubuntu和Windows实现文件互传

1.开启Ubuntu下的FTP服务&#xff1a; &#xff08;1&#xff09;终端输入&#xff1a; sudo apt-get install vsftpd&#xff08;2&#xff09;安装完成后&#xff1a; 终端输入&#xff1a; /etc 是 Linux 系统的全局配置文件目录&#xff0c;存储系统和应用程序的配置信息…

java面向对象从入门到入土

面向对象进阶 (写程序的套路) 面向:拿,找 对象:能干活的东西 面向对象编程:拿东西过来做对应的事情 (写程序的套路) 面向:拿,找 对象:能干活的东西 面向对象编程:拿东西过来做对应的事情 重点学习:学习已有对象并使用,学习如何自己设计对象并使用 设计对…

linux ACL权限控制之用户权限控制程序设计

linux中的ACL&#xff08;Access Control List&#xff0c;访问控制列表&#xff09;是一种比传统UNIX权限更细粒度的权限控制机制&#xff0c;允许为文件和目录设置更为具体的用户和组权限。本文介绍使用acl命令和程序api对文件进行更精细的用户权限控制。 1. 命令行示例 使…

Java多线程与JConsole实践:从线程状态到性能优化!!!

目录 一、前言二、JConsole 使用教程二、线程的基本状态2.1新建状态&#xff08;New&#xff09;2.2就绪状态&#xff08;Ready&#xff09;2.3运行状态&#xff08;Running&#xff09;2.4 阻塞状态&#xff08;Blocked&#xff09;2.5. 等待状态&#xff08;Waiting&#xff…

Stable Diffusion vue本地api接口对接,模型切换, ai功能集成开源项目 ollama-chat-ui-vue

1.开启Stable Diffusion的api服务 编辑webui-user.bat 添加 –api 开启api服务&#xff0c;然后保存启动就可以了 2.api 文档地址 http://127.0.0.1:7860/docs3. 文生图 接口 地址 /sdapi/v1/txt2img //post 请求入参 {enable_hr: false, // 开启高清hrdenoising_stre…

第十四届蓝桥杯真题(PWM输出)

一.LED 先配置LED的八个引脚为GPIO_OutPut&#xff0c;锁存器PD2也是&#xff0c;然后都设置为起始高电平&#xff0c;生成代码时还要去解决引脚冲突问题 二.按键 按键配置&#xff0c;由原理图按键所对引脚要GPIO_Input 生成代码&#xff0c;在文件夹中添加code文件夹&#…

【Qt】ffmpeg编码—存储(H264)

目录 一、编码分析 1.解码线程&#xff1a; ​编辑2.编码线程&#xff1a; ​编辑 ​编辑 二、ffmpeg编码 1.注册所有组件 2.编码初始化函数 &#xff08;2&#xff09;打开视频流 4.查找编码器 5. 写文件头信息&#xff0c;写到formatContex中 6.发送一帧数据给编码器…

Unity编辑器功能及拓展(1) —特殊的Editor文件夹

Unity中的Editor文件夹是一个具有特殊用途的目录&#xff0c;主要用于存放与编辑器扩展功能相关的脚本和资源。 一.纠缠不清的UnityEditor 我们Unity中进行游戏构建时&#xff0c;我们经常遇到关于UnityEditor相关命名空间丢失的报错&#xff0c;这时候&#xff0c;只得将报错…

REC一些操作解法

一.Linux命令长度突破 1.源码如下 <?php $param $_REQUEST[param];if ( strlen($param) < 8 ) {echo shell_exec($param); } 2.源码分析 echo执行函数&#xff0c;$_REQUEST可以接post、get、cookie传参 3.破题思路 源码中对参数长度做了限制&#xff0c;小于8位&a…

[AI绘图] ComfyUI 中自定义节点插件安装方法

ComfyUI 是一个强大的 AI 图像生成工具,支持自定义节点插件扩展其功能。本文介绍 ComfyUI 中安装自定义节点插件的三种方法,包括 Git Clone 方式、插件管理器安装方式,以及手动解压 ZIP 文件的方法,并分析它们的优缺点。 1. Git Clone 方法 使用 git clone 是最稳定且推荐…

【机械视觉】C#+VisionPro联合编程———【六、visionPro连接工业相机设备】

【机械视觉】C#VisionPro联合编程———【六、visionPro连接工业相机设备】 目录 【机械视觉】C#VisionPro联合编程———【六、visionPro连接工业相机设备】 前言&#xff1a; 连接步骤说明 一. 硬件连接 支持的相机接口类型&#xff1a; 连接步骤 2. 软件配置 Visio…

蓝桥杯 之 图论基础+并查集

文章目录 习题联盟X蓝桥幼儿园 图论基础 并查集 并查集&#xff0c;总的来说&#xff0c;操作分为三步初始化(每一个节点的父亲是自己)&#xff0c;定义union(index1,index2)函数&#xff0c;定义find(index)函数 并查集详细内容博客 习题 联盟X 联盟X 典型的求解连通分支…