洛谷P4868 Preprefix sum

洛谷傳送門

題目描述

前綴和(prefix sum)𝑆𝑖=\sum a_{i}

前前綴和(preprefix sum)則把?𝑆𝑖 作為原序列再進行前綴和。記再次求得前綴和第?𝑖?個是?𝑆𝑆𝑖。

給一個長度?𝑛?的序列?𝑎1,𝑎2,??,𝑎𝑛有兩種操作:

  1. Modify i x:把?𝑎𝑖 改成?𝑥。
  2. Query i:查詢?𝑆𝑆𝑖。

輸入格式

第一行給出兩個整數?𝑁,𝑀。分別表示序列長度和操作個數。
接下來一行有?𝑁?個數,即給定的序列?𝑎1,𝑎2,??,𝑎𝑛?。
接下來?𝑀?行,每行對應一個操作,格式見題目描述。

輸出格式

對于每個詢問操作,輸出一行,表示所詢問的?𝑆𝑆𝑖?的值。

輸入輸出樣例

輸入

5 3
1 2 3 4 5
Query 5
Modify 3 2
Query 5

輸出?

35
32

說明/提示

1≤𝑁,𝑀≤1e5,且在任意時刻?0≤𝐴𝑖≤1e5。

題目解讀

? ? ? ? 由題意知,題目的意思就是求前綴和的前綴和,下面是一個酣暢淋漓的數學推理

數學推理

? ? ? ? 舉個例子:

? ? ? ? ?

//對于   1 2 3 4 5
//   a[]=1 2 3 4 5
//s[1]=1
//s[2]=1+2
//s[3]=1+2+3
//s[4]=1+2+3+4
//s[5]=1+2+3+4+5
//ss[5]=s[1]+s[2]+s[3]+s[4]+s[5]
//     =1*5++2*(5-1)+3*(5-2)+4*(5-3)+5*(5-4)

?

? ? ? ? 依此類推,我們可以發現ss_{k}=\sum (k-i+1)a_{i}=k\sum a_{i}-\sum(i-1)a_{i}

方法

? ? ? ? 我們用兩個樹狀數組 c 與 c1,分別維護\sum a_{i}( k 為常數不管),\sum (i-1)a_{i}

Code

#include<bits/stdc++.h>
using namespace std;
const long long N=1e5+5;
long long n,m,a[N],c[N],c1[N],id[N],ni[N];
long long lowbit(long long x){return (-x)&x;}
void add(long long x,long long y){for(;x<=n+1;x+=lowbit(x))c[x]+=y;}//將 c[x] 加上 y
void add1(long long x,long long y){for(;x<=n+1;x+=lowbit(x))c1[x]+=y;}//將 c1[x] 加上 y
long long sum(long long x){//求 c 的前綴和long long ret=0;for(;x;x-=lowbit(x))ret+=c[x];return ret;
}
long long sum1(long long x){//求 c1 的前綴和long long ret=0;for(;x;x-=lowbit(x))ret+=c1[x];return ret;
}
int main(){cin>>n>>m;for(int i=1;i<=n;i++){cin>>a[i];add(i,a[i]-0);add1(i,(i-1)*(a[i]-0));//分別向 c 和 c1 加入 a[i] 和 (i-1)*a[i]}string t;int x,y;for(int i=1;i<=m;i++){cin>>t;if(t=="Query"){cin>>x;cout<<x*sum(x)-sum1(x)<<'\n';//輸出結果}else{cin>>x>>y;add(x,y-a[x]);add1(x,(x-1)*(y-a[x]));//修改a[x]=y;}}return 0;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/66163.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/66163.shtml
英文地址,請注明出處:http://en.pswp.cn/web/66163.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

機器學習中的凸函數和梯度下降法

一、凸函數 在機器學習中&#xff0c;凸函數 和 凸優化 是優化問題中的重要概念&#xff0c;許多機器學習算法的目標是優化一個凸函數。這些概念的核心思想圍繞著優化問題的簡化和求解效率。下面從簡單直觀的角度來解釋。 1. 什么是凸函數&#xff1f; 數學定義 一個函數 f…

vue3使用vue-native-websocket-vue3通訊

vue3使用vue-native-websocket-vue3通訊 插件使用一、啟用Vuex集成1.在mian.js中2.store/index.js文件中3.要websocket使用的頁面 二、啟用Piain集成1.在mian.js中2.根目錄下創建store文件夾&#xff0c;分別創建PiniaType.ts&#xff0c;store.ts&#xff0c;useSocketStore.t…

Windows圖形界面(GUI)-QT-C/C++ - Qt控件與布局系統詳解

公開視頻 -> 鏈接點擊跳轉公開課程博客首頁 -> ???鏈接點擊跳轉博客主頁 目錄 Qt布局系統(Layouts) 布局管理器基礎 高級布局技巧 嵌套布局 設置間距和邊距 常用控件詳解 按鈕類控件 QPushButton (標準按鈕) QRadioButton (單選按鈕) QCheckBox (復選框) …

深入理解 ECMAScript 2024 新特性:字符串 isWellFormed 方法

ECMAScript 2024 引入了一個新的字符串實例方法&#xff1a;String.prototype.isWellFormed。這一新增功能是為了幫助開發者更容易地驗證字符串是否為有效的 Unicode 文本。本文將詳細介紹這一方法的使用場景、實現原理及其在實際應用中的價值。 String.prototype.isWellFormed…

[Linux]Docker快速上手操作教程

前言 以下命令并不是docker的所有&#xff0c;僅涉及日常使用時最最常用的命令。 目的之一時給入門的朋友熟悉學習&#xff0c;其二時我自己偶爾使用時備忘。 一、概念 簡單介紹下docker的相關概念&#xff1a; 鏡像&#xff1a;Docker 鏡像是一個輕量級、可執行的獨立軟件…

【算法學習筆記】32:篩法求解歐拉函數

上節學習的是求一個數 n n n的歐拉函數&#xff0c;因為用的試除法&#xff0c;所以時間復雜度是 O ( n ) O(\sqrt{n}) O(n ?)&#xff0c;如果要求 m m m個數的歐拉函數&#xff0c;那么就會花 O ( m n ) O(m \sqrt{n}) O(mn ?)的時間。如果是求連續一批數的歐拉函數&#x…

生產管理看板助力節能科技公司實現數據自動化管理

在節能科技公司的生產過程中&#xff0c;數據管理的自動化是提高生產效率和產品質量的關鍵。然而&#xff0c;許多公司在數據記錄、展示、對比和存檔方面仍面臨諸多痛點&#xff0c;如產品檢測數據無法自動記錄、缺乏直觀的產線狀態展示、檢測數據對比繁瑣耗時&#xff0c;以及…

leetcode 115. 不同的子序列

題目&#xff1a;115. 不同的子序列 - 力扣&#xff08;LeetCode&#xff09; 動態規劃問題&#xff0c;f[i][j]表示s的第i個元素匹配到t的第j個元素&#xff0c;有多少種結果 f[i][j] f[i - 1][j] (s[i] t[j] ? f[i - 1][j - 1] : 0) 答案就是 f[s.length() - 1][t.len…

【C++】B2112 石頭剪子布

博客主頁&#xff1a; [小????????] 本文專欄: C 文章目錄 &#x1f4af;前言&#x1f4af;題目描述游戲規則&#xff1a;輸入格式&#xff1a;輸出格式&#xff1a;輸入輸出樣例&#xff1a;解題分析與實現 &#x1f4af;我的做法實現邏輯優點與不足 &#x1f4af…

內存快照:宕機后Redis如何實現快速恢復?

文章目錄 給哪些內存數據做快照&#xff1f;快照時數據能修改嗎?可以每秒做一次快照嗎&#xff1f;小結每課一問 更多redis相關知識 上節課&#xff0c;我們學習了 Redis 避免數據丟失的 AOF 方法。這個方法的好處&#xff0c;是每次執行只需要記錄操作命令&#xff0c;需要持…

系統架構設計師考點—項目管理

一、備考指南 項目管理主要考查的是進度管理、軟件配置管理、質量管理、風險管理等相關知識&#xff0c;近幾年都沒有考查過&#xff0c;但是有可能在案例分析中考查關鍵路徑的技術問題&#xff0c;考生了解為主。 二、重點考點 1、項目的十大管理&#xff08;速記&#xff1…

iOS - Objective-C 底層實現中的哈希表

1. 關聯對象存儲&#xff08;AssociationsHashMap&#xff09; // 關聯對象的哈希表實現 typedef DenseMap<const void *, ObjcAssociation> ObjectAssociationMap; typedef DenseMap<DisguisedPtr<objc_object>, ObjectAssociationMap> AssociationsHashMa…

兩分鐘解決 :![rejected] master -> master (fetch first) , 無法正常push到遠端庫

目錄 分析問題的原因解決 分析問題的原因 在git push的時候莫名遇到這種情況 若你在git上修改了如README.md的文件。由于本地是沒有README.md文件的&#xff0c;所以導致 遠端倉庫git和本地不同步。 將遠端、本地進行合并就可以很好的解決這個問題 注意&#xff1a;直接git pu…

Ubuntu Server 24.04 配置靜態IP

Ubuntu Server 24.04 配置靜態IP 提示&#xff1a;基于Ubuntu Server 24.04進行配置 文章目錄 Ubuntu Server 24.04 配置靜態IP一、查看網卡信息二、修改網卡信息三、使網卡配置生效四、測試 一、查看網卡信息 使用命令 ip a lo 為本地回環地址 ens33 真實網卡地址 shanfengubu…

微服務之松耦合

參考&#xff1a;https://microservices.io/post/architecture/2023/03/28/microservice-architecture-essentials-loose-coupling.html There’s actually two different types of coupling: runtime coupling - influences availability design-time coupling - influences…

Django 和 Vue3 前后端分離開發筆記

Django 和 Vue3 前后端分離開發筆記 1. Django Ninja API Django Ninja 是一個用于使用 Django 和 Python 3.6 類型提示構建 API 的網絡框架。它具有以下主要特點&#xff1a; 簡單易懂&#xff1a;設計為易于使用和符合直覺&#xff0c;適合快速上手。快速執行&#xff1a;…

44_Lua迭代器

在Lua中,迭代器是一種用于遍歷集合元素的重要工具。掌握迭代器的使用方法,對于提高Lua編程的效率和代碼的可讀性具有重要意義。 1.迭代器概述 1.1 迭代器介紹 迭代器是一種設計模式,它提供了一種訪問集合元素的方法,而不需要暴露其底層結構。在Lua中,迭代器通常以一個函…

hot100_240. 搜索二維矩陣 II

hot100_240. 搜索二維矩陣 II 直接遍歷列減行增 編寫一個高效的算法來搜索 m x n 矩陣 matrix 中的一個目標值 target 。該矩陣具有以下特性&#xff1a; 每行的元素從左到右升序排列。 每列的元素從上到下升序排列。 示例 1&#xff1a; 輸入&#xff1a;matrix [[1,4,7,1…

一步到位Python Django部署,淺談Python Django框架

Django是一個使用Python開發的Web應用程序框架&#xff0c;它遵循MVC&#xff08;Model-View-Controller&#xff09;設計模式&#xff0c;旨在幫助開發人員更快、更輕松地構建和維護高質量的Web應用程序。Django提供了強大的基礎設施和工具&#xff0c;以便于處理復雜的業務邏…

Apache PAIMON 學習

參考&#xff1a;Apache PAIMON&#xff1a;實時數據湖技術框架及其實踐 數據湖不僅僅是一個存儲不同類數據的技術手段&#xff0c;更是提高數據分析效率、支持數據驅動決策、加速AI發展的基礎設施。 新一代實時數據湖技術&#xff0c;Apache PAIMON兼容Apache Flink、Spark等…