算法竞赛实用板子

news/2025/3/21 2:12:44/

一、声明

        自用版参考acwing,致力于实用、好用,板子中有个人理解,持续更新。

二、开板


        1.快排

void quick_sort(int q[],int l,int r)
{if(l>=r)return;              //出口int i=l-1,j=r+1,x=q[l+r>>1]; //分治方法while(i<j){do i++;while(q[i]<x);do j--;while(q[j]>x);if(i<j)swap(q[i],q[j]);}quick_sort(q,l,j);           //递归实现   quick_sort(q,j+1,r);
}

        2.差分

for(int i=1;i<=n;i++)b[i] = a[i] - a[i - 1];   //区别于前缀和/*  1 2 3  -->  1 1 1  */ b[l] += c;     b[r + 1] -= c;

         3.二分

int bin(int l, int r)
{while (l < r){int mid = l + r + 1 >> 1;     //注意两种形式,下-1 上+1  if (check(mid)) l = mid;                       else r = mid - 1;             //             下+1 上}                                 return l;                         //             return any
}

         4.分数取模(快速幂)

        主函数中(可实现 求解 (a / b) % M  ):

ll ans = a * ksm(b, M - 2) % M;

        定义快速幂函数: 

ll ksm(ll a, ll b){ll res = 1;while(b) {if(b & 1)                    // 如果当前b的二进制数字为1,即存在res = res * a % M;       // 结果乘上当前aa = a * a % M;               // 下一位的a的值(开平方)b >>= 1;                     // b的下一位二进制数}return res;
}

 具体原理讲解可参考:C++分数取模【固定模板+讲解】


to be continued !


http://www.ppmy.cn/news/1365125.html

相关文章

【华为面试基础题】最大括号深度

描述 现有一字符串 仅由 (, ), {, }, [, ]一共六种括号组成。若字符串满足以下条件之一&#xff0c;则为无效字符串。 任意类型的左右括号数量不相等存在未按正确顺序(先左后右)闭合的括号&#xff0c; 输出括号的最大嵌套深度&#xff0c;若字符串无效则输出 0。 0 < 字符…

基于EKF扩展卡尔曼滤波的传感器网络目标跟踪matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 MATLAB2022a 3.部分核心程序 .....................................................................% 定义初始位置的均…

STL unordered_set/unordered_map 不能默认hash vector?

背景 最近在做项目的过程中&#xff0c;遇到使用unordered_set 使用的一个bug&#xff0c;这里简单来记录一下。 例子 #include <iostream> #include <vector> #include <set> #include <stack> #include <algorithm> #include <map> #i…

uniapp的扩展组件uni-popup 弹出层自动打开

我的需求是在页面加载完之后自动打开弹窗&#xff0c;自动打开只能写在onReady 或 mounted 生命周期内&#xff0c;这是这个组件的规定&#xff1a; 如果想在页面渲染完毕后就打开 uni-popup &#xff0c;请在 onReady 或 mounted 生命周期内调用&#xff0c;确保组件渲染完毕…

【一】【计算机网络】win基本命令

检查自己的信息 以太网IPv4 地址就是本地计算机。 以太网适配器 VMware Network Adapter VMnet1的IPv4 地址不是本地计算机。局域网内其他的计算机。 C:\Users\205>ipconfigWindows IP 配置以太网适配器 以太网:连接特定的 DNS 后缀 . . . . . . . :本地链接 IPv6 地址. .…

day02_前后端环境搭建(前端工程搭建,登录功能说明,后端项目搭建)

文章目录 1. 软件开发介绍1.1 软件开发流程1.2 角色分工1.3 软件环境1.4 系统的分类 2. 尚品甄选项目介绍2.1 电商基本概念2.1.1 电商简介2.1.2 电商模式B2BB2CB2B2CC2BC2CO2O 2.2 业务功能介绍2.3 系统架构介绍2.4 前后端分离开发 3. 前端工程搭建3.1 Element-Admin简介3.2 El…

目标跟踪之KCF详解

High-Speed Tracking with Kernelized Correlation Filters 使用内核化相关滤波器进行高速跟踪 大多数现代跟踪器的核心组件是判别分类器&#xff0c;其任务是区分目标和周围环境。为了应对自然图像变化&#xff0c;此分类器通常使用平移和缩放的样本补丁进行训练。此类样本集…

Eureka服务搭建

1️⃣搭建服务 引入依赖 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId></dependency>启动类加注解 EnableEurekaServer SpringBootApplication public…