我爱学算法之—— 前缀和(上)

我爱学算法之—— 前缀和(上)

一、【模板】前缀和

题目解析

在这里插入图片描述
这道题,给定一个长度为n的数组,和m次询问;

每一次询问给出两个整数lr,让我们求出区间[l , r]中所有数的和,然后输出。

算法思路

这道题暴力解法:

首先是m次查询(m次测试),每一个给定一个lr,让我们求区间[l , r]中所有数的和。

暴力解法就非常简单了,直接遍历区间[l , r],求出区间中所有数的和即可。

暴力解法时间复杂度O(m * n),也就是O(n^2)级别的时间复杂度;

暴力解法会超时,我们这里想一想可不可以对暴力解法进行一些优化:

  1. 首先m次查询,很显然是不能进行优化的。
  2. 我们只能对求区间[l , r]中所有数的和进行优化。

那如何优化呢?

遍历区间[l , r]来求和时间复杂度是O(n),那我们可不可以用O(1)的复杂度来获得区间[l , r]中所有数的和呢?
在这里插入图片描述

通过上图,我们可以发现:我们要求的[l , r]区间的和s就等于区间[1 , r]的和 减去区间[1 , l]的和。

前缀和

所以,我们可以通过运算来用O(1)的时间复杂度获得区间[l , r]中所有数的和;但是我们要用到区间[1 , l]和区间[1 , r]中所有数的和。

所以我们预先既要处理一个前缀和数组dp:其中dp[i]:表示区间[1 , i]中所有数的和。填写前缀和数组:dp[i] = dp[i-1] + arr[i](也就是前面所有数的和加上当前位置的数)。计算区间[l , r]中所有数的和:dp[r] - dp[l-1](这里区间[l , r]包含l位置,所以要减去dp[i-1]
这里可以说:前缀和和动态规划的大致思路非常相似:

状态表示dp[i]表示区间[1 , i]中所有数的和

状态转移方程dp[i] = dp[i] + arr[i];

获取区间[l , r]中所有数的和s = dp[r] - dp[l-1];

代码实现

#include<cmath>#include<iostream>usingnamespace std;constint N =100001;longlong dp[N];int arr[N];int n, m;intmain(){ cin >> n >> m;for(int i =1; i <= n; i++){ cin >> arr[i]; dp[i]= dp[i -1]+ arr[i];}while(m--){int l, r; cin >> l >> r; cout << dp[r]- dp[l -1]<< endl;}return0;}

二、【模板】二维前缀和

题目解析

在这里插入图片描述
对于这道题,给定一个n*m的二维数组,以及q次查询;

每一次查询给定x1,x2,y1,y2,我们要求以(x1,y1)为左上角,(x2,y2)为右下角的子矩阵中所有数的和。

算法思路

暴力解法:

q次查询,每一查询给定x1,y1,x2,y2,遍历整个子矩阵进行求和操作。

时间复杂度:O(n*m*q),也就是O(n^3)级别的时间复杂度。

很显然会超时,对暴力解法进行优化,很显然只能优化求子矩阵中所有元素的和。

暴力解法中,遍历整个子矩阵去求和,这样太麻烦了;我们可不可以使用O(1)的时间复杂度拿到子矩阵中所有数的和?

当然也是可以的,这就像数学当中求一块面积的和一样。
在这里插入图片描述

如上图所示,我们要求以(x1 , y1)为左上角,(x2 , y2)为右下角的子矩阵中所有数的和,也就是S

我们只要知道s1(以(1 , 1)为左上角,(x1-1 , y1)为右下角的子矩阵的和)、s2(以(1 , 1)为左上角,(x2, y1-1)为右下角的子矩阵的和)、s3(以(1 , 1)为左上角,(x1-1 , y1-1)为右下角的子矩阵的和)以及s4(以(1 , 1)为左上角,(x2 , y2)为右下角的子矩阵的和)。

我们就可以通过数学运算来求Ss = s4 - s1 - s2 + s3

也就是s = dp[x2][y2] - dp[x2][y1-1] - dp[x1-1][y2] + dp[x1-1][y1-1]

这样我们在填写前缀和表时:

在这里插入图片描述

dp[i][j] = dp[i][j-1] +dp[i-1][j] - dp[i-1][j-1] + arr[i][j]

这里也可以将前缀和理解为动态规划

状态表示dp[i][j]表示以(1,1)为左上角,(i,j)为右下角的子矩阵中所有数的和。

状态转移方程dp[i][j] = dp[i][j-1] +dp[i-1][j] - dp[i-1][j-1] + arr[i][j]

计算子矩阵中所有数的和s = dp[x2][y2] - dp[x2][y1-1] - dp[x1-1][y2] + dp[x1-1][y1-1]

代码实现

#include<iostream>usingnamespace std;constint N =1001;int arr[N][N];longlong dp[N][N];int n, m, q;int x1, x2, y1, y2;intmain(){ cin >> n >> m >> q;for(int i =1; i <= n; i++){for(int j =1; j <= m; j++){ cin >> arr[i][j]; dp[i][j]= dp[i -1][j]+ dp[i][j -1]- dp[i -1][j -1]+ arr[i][j];}}while(q--){ cin >> x1 >> y1 >> x2 >> y2; cout <<(dp[x2][y2]- dp[x1 -1][y2]- dp[x2][y1 -1]+ dp[x1 -1][y1 -1])<< endl;}return0;}

总结

这里简单总结一下前缀和算法:

首先前缀和算法可以用来快速的求出子数组/子矩阵中所有数的和,在涉及到求子数组/子矩阵的和时,能够利用前缀和算法来快速的求和。

其次,使用前缀和,我们就要预先构建一个前缀和数组并填写该数组;(和动态规划类似)

注意:在构建前缀和数组时,通常下标从1开始,因为在填写数组时要用到dp[i-1]

最后,前缀和算法就是空间换时间,通过预先构建前缀和数组,让我们能够在O(1)的数据复杂度拿到子数组/子矩阵的和。

到这里本篇文章内容就结束了,感谢各位大佬的支持

Read more

医疗AI场景下算法编程的深度解析(2026新生培训讲稿)(八)

医疗AI场景下算法编程的深度解析(2026新生培训讲稿)(八)

第15章 模型融合与集成策略 在机器学习竞赛和实际应用中,模型融合(Model Ensemble)是提升预测性能的利器。通过组合多个不同的基模型,集成策略能够综合各个模型的优势,抵消单个模型的偏差和方差,从而获得比任何单一模型更稳定、更准确的预测结果。在医疗AI领域,模型融合同样具有重要价值——面对复杂多模态的医疗数据,单一模型往往难以全面捕捉所有信息,而融合多个异质模型可以提升诊断的鲁棒性和准确性。本章将从集成学习的基本思想出发,系统介绍常见的模型融合方法,包括投票法、平均法、Stacking、Blending等,并通过实战案例展示如何构建融合模型来提升疾病预测性能。 15.1 集成学习的基本思想 集成学习(Ensemble Learning)的核心思想是“三个臭皮匠,顶个诸葛亮”——通过结合多个学习器来完成学习任务,通常可以获得比单一学习器更优越的泛化性能。根据个体学习器的生成方式,集成学习主要分为两大类: * Bagging:并行训练多个独立的基学习器,然后通过平均或投票进行结合。典型代表是随机森林。Bagging主要降低方差。 * Boosting:串行训练基学习

By Ne0inhk
人工智能:自然语言处理高级应用与前沿发展

人工智能:自然语言处理高级应用与前沿发展

人工智能:自然语言处理高级应用与前沿发展 学习目标 💡 理解自然语言处理(NLP)的前沿技术和发展趋势 💡 掌握高级NLP应用(如文本生成、情感分析、机器翻译) 💡 学会使用前沿NLP模型(如GPT-3、BERT、T5) 💡 理解NLP在多模态融合、零样本学习、少样本学习中的应用 💡 通过实战项目,开发一个高级文本生成应用 重点内容 * NLP前沿技术和发展趋势 * 高级NLP应用(文本生成、情感分析、机器翻译) * 前沿NLP模型(GPT-3、BERT、T5) * 多模态融合、零样本学习、少样本学习 * 实战项目:高级文本生成应用开发 一、NLP前沿技术和发展趋势 1.1 多模态融合 1.1.1 多模态融合的基本概念 多模态融合是将不同模态的数据(如文本、图像、音频)结合起来,进行处理和分析的过程。它可以提高模型的性能和准确性。

By Ne0inhk
OpenClaw接入企业微信全攻略:从0到1打通企业AI协作通道

OpenClaw接入企业微信全攻略:从0到1打通企业AI协作通道

摘要:本文详细介绍了将OpenClaw AI框架接入企业微信的完整方案。通过两种主流接入方式(API模式机器人和自建应用),企业可以快速实现智能问答、流程自动化等AI能力落地。文章重点讲解了从前期准备、核心接入流程到生产环境部署的全套实操步骤,包括权限配置、网络设置、参数对接等关键环节。同时提供了进阶优化建议,如后台守护、HTTPS加固、权限管控等企业级功能配置,以及常见问题排查方法。该方案能有效解决企业信息孤岛问题,将AI能力无缝嵌入员工日常办公场景,在保障数据安全的同时显著提升工作效率。 目录 一、前言:为什么要将OpenClaw接入企业微信? 二、接入前置准备 OpenClaw介绍 接入准备工作 三、核心接入流程(两种方案任选) 方案一:API模式机器人接入(新手首选,快速上手) 步骤1:企业微信后台创建API模式机器人 步骤2:OpenClaw安装企微插件并配置参数 步骤3:完成机器人创建并测试联调 方案二:企业微信自建应用接入(企业级进阶方案) 步骤1:企业微信创建自建应用并获取核心凭证 步骤2:OpenClaw配置自建应用核心参数 步骤3:启用应

By Ne0inhk