差分: 模板+題目

題目:【模板】差分

應用場景:快速解決將某一個區間所有元素加上 “一個數” 的操作。

第一步,預處理差分數組。

f[i] 表示:當前元素與前一個元素的差值? ??a[i] - a[i-1];

但在題目中,我們其實可以不用到a[]這個數組,只使用f[]數組。我們可以先減后加:(易錯)

		LL x; cin >> x;f[i+1] -= x;   //可以不用創建a[],直接使用f[]  先減后加f[i] += x;

第二步,利用差分數組解決m次修改操作

第三步,如何還原數組

直接對差分數組做前綴和運算即可。(前面的數變大,后面的數加上前面的數自然會變大)

#include <iostream>using namespace std;
typedef long long LL;
const int N = 1e6 + 10;
LL f[N]; int n, m; int main()
{cin >> n >> m;//有幾個數,有m次操作for (int i = 1; i <= n; i++){LL x; cin >> x;f[i+1] -= x;   //可以不用創建a[]:  先減后加f[i] += x;}while(m--){LL l, r, k; cin >> l >> r >> k;f[l] += k; f[r+1] -= k;} for (int i = 1; i <= n; i++){f[i] = f[i-1] + f[i];cout << f[i] << " ";}return 0;
}

題目:P3406 海底高鐵 - 洛谷

#include <iostream>using namespace std;
const int N = 1e6 + 10;
typedef long long LL;LL f[N];
int n, m;
LL sum = 0;//第二段鐵路連接城市2-3 ,每次單獨購買車票 
//花Ci買卡,乘坐只要扣給Bi元 //N,M  表示N個城市,N-1段鐵路   要訪問M個城市
//M個要訪問的城市
//N-1個單獨車票,買卡,買卡票 int main()
{cin >> n >> m;int x; cin >> x;int y;for (int i = 2; i <= m; i++){cin >> y;if (x > y){f[y]++;f[x]--;}else{f[y]--;f[x]++;}x = y;}for (int i = 1; i <= n; i++){f[i+1] += f[i];}for (int i = 1; i < n; i++){LL a, b, c; cin >> a >> b >> c;sum += min(f[i]*a, c+f[i]*b);}cout << sum << endl; return 0;
}

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

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

相關文章

GD32 Timer+ADC多通道+DMA+PWM調試記錄

本例記錄使用GD32307C開發板&#xff0c;實現以內部Timer1 CH1為觸發源&#xff0c;觸發ADC0的兩個通道&#xff0c;進行并行非連續采樣&#xff0c;病通過DMA傳輸采樣結果。同時輸出PWM&#xff0c;用來檢測Timer1 CH1的觸發周期。下面介紹具體實現過程&#xff1a;1. gpio初始…

阻塞 IO為什么叫BIO,非阻塞IO為什么叫NIO,異步IO為什么叫AIO

IOIO的核心就是數據傳輸&#xff0c;也就是程序與外部設備之間進行傳輸&#xff0c;通過IO的核心可以分為&#xff0c;文件IO和網絡IO文件IO交互的對象就是本地存儲設備&#xff0c;比方說讀寫本地文件。網絡IO交互的對象就是網絡設備&#xff0c;核心的應用場景就是網絡通信。…

10分鐘了解什么是多模態大模型

10分鐘了解什么是多模態大模型&#xff08;MM-LLMs&#xff09; 1. 什么是多模態 Multimodality 多模態&#xff08;Multimodality&#xff09;是指集成和處理兩種或兩種以上不同類型的信息或數據的方法和技術。在機器學習和人工智能領域&#xff0c;多模態涉及的數據類型通常…

通過DSL生成Jenkins流水線

代碼化管理 Jenkins 流水線&#xff08;Infrastructure as Code&#xff09; 版本控制&#xff1a;DSL 腳本可以像代碼一樣存入 Git、GitLab 等版本控制系統&#xff0c;所有任務配置的變更都有提交記錄&#xff0c;便于追溯歷史、回滾錯誤。協作效率&#xff1a;團隊成員可以通…

信號量主要API及綜合應用

1.信號量概述信號量是一個底層核心模塊【int】類型變量&#xff0c;記錄當前信號量數據。信號量 P 操作 (sem_wait)線程檢測對應信號量底層 int 數據數值&#xff0c;如果大于 0&#xff0c;當前線程獲得 CPU 執行權&#xff0c;同時將信號量底層 int 數據-1 操作。如果底層數據…

工業自動化領域的“超級跑車”:西門子TDC系統深度解析與實戰架構

工業自動化領域的“超級跑車”&#xff1a;西門子TDC系統深度解析與實戰架構 文章目錄 工業自動化領域的“超級跑車”&#xff1a;西門子TDC系統深度解析與實戰架構引言&#xff1a;當普通PLC遇到性能瓶頸第一章&#xff1a;認識TDC——它不是簡單的“大型PLC”1.1 TDC究竟是什…

MySQL高階查詢語句與視圖實戰指南

MySQL高階查詢語句與視圖實戰指南 文章目錄MySQL高階查詢語句與視圖實戰指南一、常用高階查詢技巧1. 按關鍵字排序&#xff08;ORDER BY&#xff09;基礎用法進階用法&#xff1a;多字段排序條件過濾2. 區間判斷與去重&#xff08;AND/OR DISTINCT&#xff09;區間判斷&#x…

解決Pytest參數化測試中文顯示亂碼問題:兩種高效方法

在使用Pytest進行參數化測試時&#xff0c;許多開發者都會遇到一個常見但令人頭疼的問題&#xff1a;當測試用例的ids參數包含中文字符時&#xff0c;控制臺輸出會出現亂碼。這不僅影響了測試報告的可讀性&#xff0c;也給測試結果的分析帶來了困難。本文將深入探討這個問題&am…

基于SpringBoot的校園流浪動物救助平臺【spring boot實戰項目、Java畢設、Java項目、Java實戰】

&#x1f496;&#x1f496;作者&#xff1a;計算機畢業設計小途 &#x1f499;&#x1f499;個人簡介&#xff1a;曾長期從事計算機專業培訓教學&#xff0c;本人也熱愛上課教學&#xff0c;語言擅長Java、微信小程序、Python、Golang、安卓Android等&#xff0c;開發項目包括…

利用kimi k2編寫postgresql協議服務端的嘗試

美團龍貓還是很有自知之明的 提問請用C編寫postgresql協議服務端&#xff0c;能接收psql客戶端或其他采用postgresql協議的工具的請求&#xff0c;實現將用戶請求打印在控制臺&#xff0c;并把回應發給客戶端回答 抱歉&#xff0c;我無法為您編寫完整的 PostgreSQL 協議服務端。…

醫療 AI 再突破:輔助診斷準確率超 90%,但落地醫院仍面臨數據安全與臨床信任難題

一、引言&#xff08;一&#xff09;醫療 AI 發展背景在數字化與智能化浪潮的席卷下&#xff0c;醫療領域正經歷著深刻變革&#xff0c;人工智能&#xff08;AI&#xff09;技術的融入成為這場變革的關鍵驅動力。近年來&#xff0c;醫療 AI 輔助診斷技術取得重大突破&#xff0…

Rocky Linux10.0安裝zabbix7.4詳細步驟

安裝Rocky Linux10.0系統 請參考Rocky Linux10.0安裝教程-CSDN博客 查看當前系統版本 cat /etc/*release 安裝數據庫 安裝zabbix之前&#xff0c;需要先安裝一個數據庫來承載zabbix的數據。這里我選擇在本機直接安裝一個MariaDB數據庫。 Rocky Linux10.0系統默認不包含MySQ…

JDBC插入數據

文章目錄視頻&#xff1a;JDBC插入數據環境準備寫插入數據屬性配置屬性配置視頻&#xff1a;JDBC插入數據 環境準備 MySQL環境 小皮面板 提供MySQL環境 寫插入數據 屬性配置 聲明變量 屬性配置 # . properties 是一個特俗的map 集合 # key : 字符串 value : 字符串…

GPU 服務器壓力測試核心工具全解析:gpu-burn、cpu-burn 與 CUDA Samples

在 GPU 服務器的性能驗證、穩定性排查與運維管理中,壓力測試是關鍵環節,可有效檢測硬件極限性能、散熱效率及潛在故障。以下從工具原理、核心功能、使用場景等維度,詳細介紹三款核心測試工具,幫助用戶系統掌握 GPU 服務器壓力測試方法。 一、GPU 專屬壓力測試工具:gpu-bu…

Python進程和線程——多線程

前面提到過進程是由很多線程組成的&#xff0c;那么今天廖老師就詳細解釋了線程是如何運行的。首先&#xff0c;&#xff0c;Python的標準庫提供了兩個模塊&#xff1a;_thread和threading&#xff0c;_thread是低級模塊&#xff0c;threading是高級模塊&#xff0c;對_thread進…

【MySQL|第九篇】視圖、函數與優化

目錄 十、視圖 1、簡單視圖&#xff1a; 2、復雜視圖&#xff1a; 3、視圖更新&#xff1a; 十一、函數 1、函數創建&#xff1a; 十二、數據庫優化 1、索引優化&#xff1a; 2、查詢優化&#xff1a; 3、設計優化&#xff1a; 十、視圖 在 MySQL 中&#xff0c;視圖…

使用Docker和虛擬IP在一臺服務器上靈活部署多個Neo4j實例

使用Docker和虛擬IP在一臺服務器上靈活部署多個Neo4j實例 前言 在現代應用開發中&#xff0c;圖數據庫Neo4j因其強大的關系處理能力而備受青睞。但有時候我們需要在同一臺服務器上運行多個Neo4j實例&#xff0c;比如用于開發測試、多租戶環境或者A/B測試。傳統的端口映射方式…

K8s學習筆記(一):Kubernetes架構-原理-組件

Kubernetes&#xff08;簡稱 K8s&#xff09;是一款開源的容器編排平臺&#xff0c;核心目標是實現容器化應用的自動化部署、擴展、故障恢復和運維管理。其設計遵循 “主從架構”&#xff08;Control Plane Node&#xff09;&#xff0c;組件分工明確&#xff0c;通過 “聲明式…

ensp配置學習筆記 比賽版 vlan 靜態路由 ospf bgp dhcp

學習配置VLAN 虛擬局域網&#xff0c;目的讓兩臺在同一網段的設備&#xff0c;在交換機中訪問。基礎指令&#xff1a;sys 進入系統 sysname R1 修改交換機名字為R1 display cur 查看數據、端口等交換機信息 &#xff08;在端口中&#xff0c;可以直接display this 可以直接看…

倉頡編程語言青少年基礎教程:enum(枚舉)類型和Option類型

倉頡編程語言青少年基礎教程&#xff1a;enum&#xff08;枚舉&#xff09;類型和Option類型enum 和 Option 各自解決一類“語義級”問題&#xff1a;enum 讓“取值只在有限集合內”的約束從注釋變成編譯器強制&#xff1b;Option 讓“值可能不存在”的語義顯式化。enum類型enu…