当前位置: 首页 > article >正文

C++ 常用算法模板整理【蓝桥杯】

文章目录前言一、基础数据结构与算法二、图论 / 搜索算法三、数论算法四、动态规划算法总结前言为方便日常刷题与竞赛使用本文整理了常用的 C 算法模板基础算法、搜索、图论、数论及动态规划等核心内容。一、基础数据结构与算法1.求区间和用前缀和#includeiostream#includevectorusingnamespacestd;constintN1e510;inta[N],s[N];// 数组a前缀和数组sintmain(){intn5;for(inti1;in;i){cina[i];}// 计算前缀和s[i] a[1] a[2] ... a[i]for(inti1;in;i){s[i]s[i-1]a[i];}intl2,r4;// 区间[l,r]的和s[r]-s[l-1]couts[r]-s[l-1]endl;return0;}2.找答案有单调性用二分// 在有序数组a中找到第一个 x的位置intlower_bound(inta[],intn,intx){intl0,rn-1;while(lr){intmidlr1;//等价于(lr)/2防溢出if(a[mid]x){rmid;}elselmid1;}returnl;}二、图论 / 搜索算法3.迷宫连通块用深度优先搜索走到底constintMAXN105;intdx[]{-1,1,0,0};// 上下左右四个方向intdy[]{0,0,-1,1};boolvis[MAXN][MAXN];// 访问标记数组// 从(x,y)出发DFS遍历连通块voiddfs(intx,inty){vis[x][y]true;// 标记已访问for(inti0;i4;i){intnxxdx[i];intnyydy[i];// 边界判断未访问if(nx0nxMAXNny0nyMAXN!vis[nx][ny]){dfs(nx,ny);}}}4.求最短路径最少步数用广度优先搜索#includequeueconstintMAXN105;intdx[]{-1,1,0,0};intdy[]{0,0,-1,1};boolvis[MAXN][MAXN];// 从(sx, sy)出发BFS求最短路径无权图voidbfs(intsx,intsy){queuepairint,intq;q.push({sx,sy});vis[sx][sy]true;while(!q.empty()){auto[x,y]q.front();q.pop();for(inti0;i4;i){intnxxdx[i];intnyydy[i];if(nx0nxMAXNny0nyMAXN!vis[nx][ny]){vis[nx][ny]true;q.push({nx,ny});}}}}5.判断连通朋友圈用并查集constintN1e510;intfa[N];// 父节点数组// 初始化每个元素的父节点是自己voidinit(intn){for(inti1;in;i){fa[i]i;}}// 查找x的根节点路径压缩intfind(intx){if(fa[x]!x){fa[x]find(fa[x]);}returnfa[x];}// 合并x和y所在的集合voidunite(intx,inty){intfxfind(x);intfyfind(y);if(fx!fy){fa[fy]fx;}}三、数论算法6.素数质数多用埃式筛constintMAX_N100005;vectorintprime;boolis_prime[MAX_N];// 埃氏筛核心函数voidEra(){for(inti2;iMAX_N;i){is_prime[i]true;}for(inti2;iMAX_N;i){if(is_prime[i]){prime.push_back(i);}if((longlong)i*iMAX_N){continue;}for(intji*i;jMAX_N;ji){is_prime[j]false;}}}7.大指数幂取模用快速幂// 计算(a^b)%modlonglongqpow(longlonga,longlongb,longlongmod){longlongres1;a%mod;//先取模避免溢出while(b0){if(b1){resres*a%mod;//二进制末位为1乘入结果}aa*a%mod;//底数平方b1;//指数右移一位}returnres;}四、动态规划算法8.选或不选不限容量用0-1背包#includealgorithmusingnamespacestd;constintN1010;intw[N],v[N];//w[i]第i个物品的重量v[i]第i个物品的价值intdp[N];//dp[j]容量为j时的最大价值//n物品数量C背包总容量intbag01(intn,intC){//初始化dp数组为0fill(dp,dpC1,0);for(inti1;in;i){//逆序遍历防止重复选同一个物品for(intjC;jw[i];j--){dp[j]max(dp[j],dp[j-w[i]]v[i]);}}returndp[C];}9.最长递增子序列用LIS模板#includealgorithmusingnamespacestd;constintN1005;inta[N],dp[N];// 求数组a的最长递增子序列长度intLIS(inta[],intn){intans1;for(inti0;in;i){dp[i]1;// 每个元素自身长度为1for(intj0;ji;j){if(a[j]a[i]){dp[i]max(dp[i],dp[j]1);}}ansmax(ans,dp[i]);}returnans;}总结以上是常用算法的核心 C 实现模板熟练掌握并灵活运用这些基础代码能够有效提升编程效率与解题速度。

相关文章:

C++ 常用算法模板整理【蓝桥杯】

文章目录前言一、基础数据结构与算法二、图论 / 搜索算法三、数论算法四、动态规划算法总结前言 为方便日常刷题与竞赛使用,本文整理了常用的 C 算法模板,基础算法、搜索、图论、数论及动态规划等核心内容。 一、基础数据结构与算法 1.求区间和&#x…...

优化Better BibTeX:解决中文文献引用格式过长问题

1. 中文文献引用格式过长的痛点 写论文时引用中文文献的朋友们,一定遇到过这样的尴尬:参考文献列表里突然冒出一串长得离谱的引用标识符,比如"XuHuoJiBoDaoJiChengGuangXueXiangKongZhenXinPianSheJiNanDianYuTuPo2024"。这种标识符…...

【VM】VMware虚拟机安装指南:VMware虚拟机下载配置使用教程(超详细)

VMware(简称 VM)是一款功能强大的虚拟化软件,专门用于在单一物理计算机上创建和运行多个虚拟操作系统。如果你需要在同一台电脑上运行多个操作系统,或者想要测试软件、搭建开发环境而不影响主系统,那么VMware绝对是你的…...

高性能PCB逆向工程工具:OpenBoardView企业级电路板分析架构解析

高性能PCB逆向工程工具:OpenBoardView企业级电路板分析架构解析 【免费下载链接】OpenBoardView View .brd files 项目地址: https://gitcode.com/gh_mirrors/op/OpenBoardView OpenBoardView是一款面向硬件工程师和PCB逆向工程的专业级开源电路板文件查看器…...

从引物选择到功能预测:基于 QIIME2 的 16S rRNA 测序全流程实战与深度解析

1. 16S rRNA测序基础与实验设计 第一次接触16S rRNA测序时,我被各种专业术语搞得晕头转向。后来才发现,理解这个技术就像学习一门新语言,只要掌握核心逻辑就能豁然开朗。16S rRNA基因相当于细菌的"身份证",每个物种的这…...

mPLUG-Owl3-2B图文交互工具入门必看:上传→提问→解析三步闭环

mPLUG-Owl3-2B图文交互工具入门必看:上传→提问→解析三步闭环 本文约3800字,阅读时间约12分钟,包含完整操作指南和实用技巧 1. 工具简介:你的本地图文助手 今天给大家介绍一个特别实用的工具——mPLUG-Owl3-2B图文交互工具。这是…...

YOLOv10新手必看:镜像内Markdown文档,帮你秒懂所有操作

YOLOv10新手必看:镜像内Markdown文档,帮你秒懂所有操作 1. 为什么选择YOLOv10镜像 对于刚接触目标检测的新手来说,最头疼的往往不是算法本身,而是复杂的环境配置和部署问题。YOLOv10官版镜像彻底解决了这个痛点,它将…...

StructBERT中文情感分析模型高可用部署方案

StructBERT中文情感分析模型高可用部署方案 1. 引言 在实际业务场景中,一个情感分析模型不仅要准确,更要稳定可靠。想象一下,电商平台的用户评论实时分析、客服系统的情绪识别、社交媒体的舆情监控——这些场景都需要724小时不间断的服务。…...

从STGCN到城市脉搏:图卷积网络如何精准预测未来交通流

1. 城市交通的"数字听诊器":STGCN如何感知交通脉搏 想象一下医生用听诊器捕捉心跳的节奏和强度,STGCN(时空图卷积网络)就是城市交通系统的数字听诊器。这个由北大团队提出的深度学习框架,正在改变我们理解和…...

netsh interface portproxy实战:Windows本地端口转发与虚拟IP配置全解析

1. 为什么需要Windows本地端口转发? 很多开发者都遇到过这样的场景:你在本地机器上跑了一个Web服务,监听的是127.0.0.1:8080,这时候同一局域网的其他设备想要访问这个服务,直接输入你的IP地址加端口是访问不了的。这是…...

避开这些坑!Windows安装LaTeX环境常见问题解决方案大全

避开这些坑!Windows安装LaTeX环境常见问题解决方案大全 LaTeX作为学术写作的黄金标准工具,在Windows平台上的安装过程却常常成为新手的第一道门槛。从镜像下载龟速到编辑器配置混乱,每个环节都可能隐藏着意想不到的陷阱。本文将解剖七个典型安…...

Qwen3-VL-8B聊天系统实战场景:多模态AI助手在企业中的应用

Qwen3-VL-8B聊天系统实战场景:多模态AI助手在企业中的应用 1. 企业级多模态AI助手的核心价值 在数字化转型浪潮中,企业正面临信息处理效率与智能化服务的双重挑战。Qwen3-VL-8B聊天系统作为新一代多模态AI解决方案,通过融合视觉与语言理解能…...

终极指南:如何让Intel Mac保持凉爽的3个简单技巧

终极指南:如何让Intel Mac保持凉爽的3个简单技巧 【免费下载链接】smcFanControl Control the fans of every Intel Mac to make it run cooler 项目地址: https://gitcode.com/gh_mirrors/smc/smcFanControl 你是否曾经在使用Intel Mac进行视频剪辑或编程时…...

深度解析163MusicLyrics:打造高效专业的云音乐歌词获取与处理终极方案

深度解析163MusicLyrics:打造高效专业的云音乐歌词获取与处理终极方案 【免费下载链接】163MusicLyrics 云音乐歌词获取处理工具【网易云、QQ音乐】 项目地址: https://gitcode.com/GitHub_Trending/16/163MusicLyrics 在音乐数字化时代,精准的歌…...

ROS2新手必看:rqt图形化工具从安装到实战(附小乌龟控制技巧)

ROS2图形化利器:rqt工具从零精通到多海龟协同控制实战 第一次接触ROS2时,命令行操作总让人望而生畏。记得我刚开始调试机器人时,在终端里反复输入ros2 topic list和ros2 service call的场景至今难忘——直到发现了rqt这个可视化神器。作为ROS…...

越锻炼越痛竟是方法错了,颈椎病腰间盘突出不能盲目运动!科学防护与康复指南来了

很多人得知自己有颈椎病或腰椎间盘突出后,第一反应就是 "多运动锻炼",结果不仅没缓解症状,反而越练越痛,甚至导致病情加重。这是因为颈腰椎病患者的脊柱已经受损,错误的运动方式会进一步损伤椎间盘和神经&am…...

Vue3+TinyMCE数学公式插件实战:手把手解决kityformula-editor弹窗不显示问题

Vue3TinyMCE数学公式插件深度排障指南:从路径配置到弹窗层级的全链路解决方案 当Vue3项目遇上TinyMCE的数学公式插件kityformula-editor,开发者们常常在弹窗显示环节遭遇"幽灵现象"——点击公式按钮后要么毫无反应,要么页面直接跳转…...

暗黑破坏神2存档编辑器:3步打造你的完美游戏角色

暗黑破坏神2存档编辑器:3步打造你的完美游戏角色 【免费下载链接】d2s-editor 项目地址: https://gitcode.com/gh_mirrors/d2/d2s-editor 还在为暗黑破坏神2的角色属性不够理想而烦恼?或者想体验不同的装备组合却不想重新练级?今天我…...

体系结构论文(105):KernelCraft: Benchmarking for Agentic Close-to-MetalKernel Generation on Emerging Hardw

KernelCraft: Benchmarking for Agentic Close-to-Metal Kernel Generation on Emerging Hardware 【剑桥&AMD的26年paper】这篇文章在做什么这篇文章的核心提出了一个新的 benchmark 和 agent 评测框架:KernelCraft。它关心的问题是:对于那些“刚出…...

外卖试吃、霸王餐活动API接口怎么对接?

以微客云为例,外卖试吃 / 霸王餐 API 采用RESTfulJSON,支持美团 / 饿了么双平台,覆盖活动列表、报名 / 领取、核销、订单与统计全链路,适配小程序 / APP/H5 多端,与你常用的PHP/ThinkPHP完美适配。 🔌 核心…...

SAP VT技术面试都问啥?Python字典元组、Git操作、GenAI调参、停车场系统设计真题解析

SAP VT技术面试深度解析:从Python到系统设计的全维度备战指南 走进SAP VT技术面试考场前,大多数候选人的焦虑往往源于对考察范围的不确定。这份指南将彻底改变你的备战方式——我们不仅还原真实考题,更构建了一套可迁移的知识框架。去年参与面…...

Windows热键冲突快速排查指南:Hotkey Detective实战手册

Windows热键冲突快速排查指南:Hotkey Detective实战手册 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 你是否…...

易基因:NC/IF15.7:浙江大学陈淑洁/王良静团队acRIP-seq等揭示ac4C RNA修饰调控肠道衰老及年龄相关肠道疾病发病机制

大家好,这里是专注表观组学十余年,领跑多组学科研服务的易基因。近日,浙江大学王良静教授和陈淑洁教授团队合作,在《Nature Communications》期刊发表题为“Targeting NAT10 alleviates colonic senescence and elderly-onset col…...

BUUCTF平台实战:手把手教你利用Struts2漏洞获取flag(附工具推荐)

BUUCTF平台实战:从Struts2漏洞入门到flag获取全指南 第一次接触CTF比赛时,看到那些复杂的漏洞利用过程总让人望而生畏。直到在BUUCTF平台上遇到了Struts2系列漏洞,才发现原来漏洞利用也可以如此"标准化"。本文将带你从零开始&#…...

ROS机器人开发实战:用tf库搞定四元数、欧拉角、旋转矩阵的6种转换(附C++/Python代码)

ROS机器人开发实战:四元数、欧拉角与旋转矩阵的高效转换指南 在机器人开发中,姿态表示就像工程师的语言——四元数、欧拉角和旋转矩阵各有其独特的语法规则。记得第一次调试机械臂时,我被这些转换搞得晕头转向,直到发现tf库这个&q…...

从凯撒密码到AES:用Python手把手实现5种加密算法,理解它们的本质区别

从凯撒密码到AES:用Python手把手实现5种加密算法,理解它们的本质区别 加密技术就像数字世界的隐形护盾,从古罗马战场的密信到现代银行的在线交易,算法进化史就是一部人类与破解者斗智斗勇的编年史。今天我们将用Python这把"解…...

一款基于 .NET 开源、跨平台应用程序自动升级组件适

基础示例:单工作表 Excel 转 TXT 以下是将一个 Excel 文件中的第一个工作表转换为 TXT 的完整步骤: 1. 加载并读取Excel文件 from spire.xls import * from spire.xls.common import * workbook Workbook() workbook.LoadFromFile("示例.xlsx"…...

04-微服务篇

文章目录一、Spring Cloud1. Spring Cloud 5大组件有哪些?2. 服务注册和发现是什么意思?Spring Cloud 如何实现服务注册发现?3. 我看你之前也用过nacos,你能说下nacos与eureka的区别?4. 你们项目负载均衡如何实现的&am…...

微星主板无U更新BIOS

客户的微星PRO B650M-P 主板升级9600X cpu 开不了机,手头也没低点的U 看了下主板支持Flash BIOS Button 也就是无U盲刷BIOS 首先 U 盘需要格式化FAT32 格式 ,然后 官网下载最新BIOS解压缩后修改文件名需成 MSI.ROM ,然后复制到U盘根目录 ,插入主板BIOS USB接口 然后 插上CPU 供…...

重新定义窗口自由:SRWE如何解锁任意程序的分辨率限制

重新定义窗口自由:SRWE如何解锁任意程序的分辨率限制 【免费下载链接】SRWE Simple Runtime Window Editor 项目地址: https://gitcode.com/gh_mirrors/sr/SRWE 你是否曾因软件窗口无法调整到理想尺寸而感到束手无策?当游戏只支持有限分辨率、专业…...