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实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Python包管理工具核心指令uvx举例详细解析

《Python包管理工具核心指令uvx举例详细解析》:本文主要介绍Python包管理工具核心指令uvx的相关资料,uvx是uv工具链中用于临时运行Python命令行工具的高效执行器,依托Rust实... 目录一、uvx 的定位与核心功能二、uvx 的典型应用场景三、uvx 与传统工具对比四、uvx 的技术实

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

C++作用域和标识符查找规则详解

《C++作用域和标识符查找规则详解》在C++中,作用域(Scope)和标识符查找(IdentifierLookup)是理解代码行为的重要概念,本文将详细介绍这些规则,并通过实例来说明它们的工作原理,需... 目录作用域标识符查找规则1. 普通查找(Ordinary Lookup)2. 限定查找(Qualif

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构