C++算法 模版代码 详细介绍(CSP考试专用)

2024-08-27 22:36

本文主要是介绍C++算法 模版代码 详细介绍(CSP考试专用),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C++算法 模版代码

PS:大部分模版代码知识点都有例题 + 链接🔗!请放心食用!
TIP : 此为CSP-J/S初/复赛复习专用

废话不多说,直接开始今天的内容!

1、高精度算法:

1.1 高精度加法:

例题:信息学奥赛一本通 - 1168:大整数加法


1.2 高精度减法:


1.3 高精度乘法:


1.4 高精度除法(高精 / 低精)


2、最大公因数 & 最小公倍数

2.1 最大公因数 - 递归解法

int gcd(int a, int b) {if (b == 0) {return a;}return gcd(b, a % b);
}

2.2 最大公因数 - 非递归解法

用辗转相除法即可

int gcd(int a, int b) {while (b != 0) {int r = a % b;a = b;b = r;}return a;
}

2.3 最大公因数 - 内置函数(__gcd())

代码非常简单,加上 numeric 头文件就可以了

cout << __gcd(a, b) << endl;

2.4 最小公倍数

#include <iostream>
using namespace std;int gcd(int x, int y)
{if(y == 0)return x;return gcd(y, x - y);
}int main()
{int n, m, y;cin >> n >> m;y = gcd(max(n, m), min(n, m));cout << n * m / y << endl;        //n和m的乘积除以最大公约数=最小公倍数return 0;
}

3、深度优先搜索

我这里就不深究了,拿一道八个方向的模板题练练手即可!

例题:东方博宜 - 1435. 数池塘(八方向)

#include <bits/stdc++.h>
using namespace std;
typedef long long ll; 
ll n, m, s;
char a[100][100];
ll fx[8] = {0, 0 , 1 , -1 , -1 , -1 , 1 , 1};
ll fy[8] = {1, -1 , 0 , 0 , -1 , 1 , 1 , -1};void dfs(ll x, ll y)
{a[x][y] = '.';ll tx, ty;for (ll i = 0; i < 8; i++){tx = x + fx[i];ty = y + fy[i];if (a[tx][ty] == 'W'){dfs(tx, ty);}}
}int main()
{cin >> n >> m;for (ll i = 1; i <= n; i++){for (ll j = 1; j <= m; j++){cin >> a[i][j];}}for (ll i = 1; i <= n; i++){for (ll j = 1; j <= m; j++){if (a[i][j] == 'W'){s++;dfs(i, j);}}}cout << s << endl;return 0;
}

请关注我,我会继续更新这篇文章的!

这篇关于C++算法 模版代码 详细介绍(CSP考试专用)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112968

相关文章

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方