C语言学习笔记

一、 一维数组前缀

一维数组前缀和:构造一个与原数组长度相同的新数组 pre,pre[i] 表示原数组 arr 中 从第0个元素到第i个元素的所有元素累加和,核心价值是把「区间和查询」的时间复杂度从O(n)降到O(1)。

二、 核心公式(2个必记)

  1. 前缀和数组构建公式

◦ 边界:pre[0] = arr[0](第一个元素的前缀和就是自身)

◦ 递推:pre[i] = pre[i-1] + arr[i](i ≥ 1,当前前缀和 = 前一个前缀和 + 原数组当前元素)

  1. 区间和查询公式(求原数组 [l, r] 闭区间的和)

◦ sum(l,r) = pre[r] - (l == 0 ? 0 : pre[l-1])

◦ 简化技巧:若让前缀和数组从下标1开始,公式直接简化为 sum(l,r) = pre[r] - pre[l-1],无需判断边界,开发中更常用。

三、 2种常用实现(C语言代码)

实现1:下标从0开始(基础版,适配数组默认下标)

#include <stdio.h>int main() {
int arr[] = {2, 5, 1, 3, 4}; // 原数组
int n = sizeof(arr)/sizeof(arr[0]); // 原数组长度
int pre[n]; // 前缀和数组

// 1. 构建前缀和数组

pre[0] = arr[0];
for (int i = 1; i < n; i++) {
pre[i] = pre[i-1] + arr[i];
}

// 2. 查询区间和:比如查 [1,3](下标从0开始,对应元素5,1,3)

int l = 1, r = 3;
int sum = pre[r] - pre[l-1]; // l≠0,直接减pre[l-1]

printf("前缀和数组:");
for (int i = 0; i < n; i++) printf("%d ", pre[i]); // 输出:2 7 8 11 15
printf("\n区间[%d,%d]和:%d", l, r, sum); // 输出:9
return 0;
}

实现2:下标从1开始(实用版,无边界判断)

java 复制代码
#include <stdio.h>

int main() {
    int arr[] = {2, 5, 1, 3, 4};
    int n = sizeof(arr)/sizeof(arr[0]);
    int pre[n+1];  // 前缀和数组长度+1,下标从1开始
    pre[0] = 0;  // 前缀和第0位设为0,作为基准
    
    // 1. 构建前缀和数组
    for (int i = 1; i <= n; i++) {
        pre[i] = pre[i-1] + arr[i-1];  // 原数组下标仍从0开始
    }
    
    // 2. 查询区间和:查原数组[1,3],直接用公式 pre[r]-pre[l-1]
    int l = 2, r = 4;  // 对应原数组下标1-3,前缀和下标同步+1
    int sum = pre[r] - pre[l-1];
    
    printf("前缀和数组:");
    for (int i = 1; i <= n; i++) printf("%d ", pre[i]);  // 输出:2 7 8 11 15
    printf("\n区间和:%d", sum);  // 输出:9
    return 0;
}

四、 核心优势 & 适用场景

  1. 优势:一次构建,多次查询,构建仅需O(n),每次查询仅需O(1),适合频繁查区间和的场景。

  2. 适用场景:数组元素固定(不频繁修改)、频繁求任意区间和(如算法题、统计类需求)。

五、 易错点

  1. 下标混淆:务必区分原数组和前缀和数组的下标对应关系,推荐用下标从1开始的写法,减少错误。

  2. 数组越界:构建前缀和时,循环边界要对应数组长度,避免pre[i]超出数组范围。

  3. 元素修改:若原数组元素频繁修改,前缀和需要重新构建,此时不如直接遍历求和高效。

我可以帮你针对一道具体的区间和算法题,用前缀和写完整解题代码,需要吗?

相关推荐
Blossom.1182 小时前
GPTQ量化实战:从零手写大模型权重量化与反量化引擎
人工智能·python·算法·chatgpt·ai作画·自动化·transformer
睡醒了叭2 小时前
图像分割-传统算法-区域分割
图像处理·人工智能·算法·计算机视觉
代码游侠2 小时前
复习——网络基础知识
网络·笔记·网络协议·算法·http
沈阳信息学奥赛培训2 小时前
CCF GESP 2025/12/24 模拟测试 C++ 4级 编程题2
数据结构·算法
dddddppppp1232 小时前
c 模拟一个fat16文件系统
c语言·c++·算法
行走的bug...3 小时前
利用计算机辅助数学运算
人工智能·算法·机器学习
CoderCodingNo3 小时前
【GESP】C++五级真题(数论-素数、贪心思想考点) luogu-B4050 [GESP202409 五级] 挑战怪物
开发语言·c++·算法
小O的算法实验室3 小时前
2026年AEI SCI1区TOP,基于多策略集成粒子群算法+无人机平滑覆盖路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
小刘爱玩单片机3 小时前
【stm32简单外设篇】- 三色LED
c语言·stm32·单片机·嵌入式硬件