7.11 dp 圖

?

lcr148.棧

按放入順序推棧,能彈出的就及時彈出,最后棧空則符合要求。

判斷?takeOut?序列是否符合棧的操作邏輯,因為題目中“特殊的數據結構”其實就是棧(先進后出)。

思路如下:

1.?用一個棧來模擬圖書放入的過程。
2.?按?putIn?的順序依次將圖書推入棧中。
3.?每次推入后,檢查棧頂元素是否和?takeOut?當前待匹配的元素相同:
- 如果相同,就彈出棧頂元素,并移動?takeOut?的匹配指針。
- 重復此檢查,直到棧頂元素和待匹配元素不同。
4.?當?putIn?的元素全部處理完后,若棧為空,說明?takeOut?是正確的拿取序列,返回?true?;否則返回?false?。

class Solution {

public:

? ? bool validateBookSequences(vector<int>& putIn, vector<int>& takeOut)?

? ? {

? ? ? ? stack<int> st;

? ? ? ? int i=0;

? ? ? ? for(int& p:putIn)

? ? ? ? {

? ? ? ? ? ? st.push(p);

? ? ? ? ? ??

?while(!st.empty() && st.top()==takeOut[i])

? ? ? ? ? ? {

? ? ? ? ? ? ? ? st.pop();

? ? ? ? ? ? ? ? i++;

? ? ? ? ? ? }

? ? ? ? ? ?

? ? ? ? }

? ? ? ? return st.empty();

? ? }

};

lc2316.dfs無向圖聯通塊計算

class Solution {
public:
long long countPairs(int n, vector<vector<int>> &edges) {
vector<vector<int>> g(n);
for (auto &e: edges) {
int x = e[0], y = e[1];
g[x].push_back(y);
g[y].push_back(x); // 建圖
}

? ? ? ? vector<int> vis(n);
function<int(int)> dfs = [&](int x) -> int {
vis[x] = true; // 避免重復訪問同一個點
int size = 1;
for (int y: g[x]) {
? if (!vis[y]) {
size += dfs(y);

}
}
return size;
};

? ? ? ? long long ans = 0;
for (int i = 0, total = 0; i < n; i++) {
? if (!vis[i]) { // 未訪問的點:說明找到了一個新的連通塊
int size = dfs(i);
ans += (long) size * total;

total += size;
}
}
return ans;
}
};

lc1042. 不領接植花

鄰接表涂色

給花園涂色:

1. 建鄰接表
2.?涂色時,先看它相鄰的用了什么顏色(記在?used?里)。
3.??找第一個沒被用過的顏色,給當前花園涂上。

最后返回所有花園的顏色數組

class Solution {
public:
vector<int> gardenNoAdj(int n, vector<vector<int>>& paths) {
// 鄰接表存連接關系
vector<vector<int>> g(n);
for (auto& p : paths) {
// 花園編號轉成0開始(原是1開始)
int x = p[0] - 1, y = p[1] - 1;
g[x].push_back(y);
g[y].push_back(x);
}

? ? ? ? // 存每個花園的顏色(1-4)
vector<int> color(n);
for (int i = 0; i < n; i++)

? ? ? ? ? {
// 記錄鄰居用過的顏色
bool used[5] = {false};
for (int j : g[i]) {
used[color[j]] = true;
}

? ? ? ? ? ? // 找第一個沒被用過的顏色
int c = 1;

while (used[c]) {
c++;
}
color[i] = c;
}
return color;
}
};

?

lc3186.施咒

?

dp[i]?表示“考慮前i個不同數字時,能得到的最大總和”。

排好序后,對每個數字,要么跳過它,要么選它(同時只能搭配前面和它差≥3的數字),始終選總和最大的方案。

注意,就在于對于重復值的處理


1.?先整理數據:統計每個數字出現的次數(比如數字5出現3次,總和就是5×3),再把數字從小到大排序。
2.?動態規劃記錄最大和:用 dp[i]?表示“考慮前i個不同數字時,能得到的最大總和”。


3.?核心邏輯:
- 對每個數字?x?(帶次數?c?),先找最前面一個“和?x?的差小于3”的數字位置?j?(意味著?j?之前的數字都能和?x?共存)。
- 決策:要么不選?x?,總和就是?f[i]?(繼承前i-1個的結果);要么選?x?,總和就是?f[j] + x×c?(?j?之前的最大和加上?x?的總貢獻),取兩者更大的那個。


4.?最終結果:?f[n]?就是考慮所有數字后能得到的最大總和。

class Solution {
public:
long long maximumTotalDamage(vector<int>& power) {
unordered_map<int, int> cnt;
for (int x : power) {
cnt[x]++;
}

? ? ? ? vector<pair<int, int>> a(cnt.begin(), cnt.end());? ? //hash轉化方法
sort(a.begin(),a.end());

? ? ? ? int n = a.size();
vector<long long> f(n + 1);
for (int i = 0, j = 0; i < n; i++)

? ? ? ? ? {
auto& [x, c] = a[i];
while (a[j].first < x - 2)

? ? ? ? ? ? {
? j++;? ?// 利用了單調性
}
?f[i + 1] = max(f[i], f[j] + (long long) x * c);

//選不選
}
return f[n];
}
};

?

?

lc2222. 狀態機dp

簡單dp:

?dp[k][j]? 記錄“選 ?k? 個字符、最后是 ?j?”的方案數,

class Solution {
typedef long long ll;
public:
long long numberOfWays(string s)
{

int n=s.size();
if(n<3) return 0;
vector<vector<ll>> dp(4,vector<ll>(2,0));
dp[0][1]=dp[0][0]=1;

for(int i=0;i<n;i++)? //遍歷子串,填表
{
//k要倒著加,要不然就多加了
for(int k=3;k>=1;k--)

{
if(s[i]=='0')
dp[k][0]+=dp[k-1][1];
else
dp[k][1]+=dp[k-1][0];
}
}
return dp[3][0]+dp[3][1];
}
};

k? 倒著遍歷是為了 確保狀態轉移時,?dp[k-1][...]? 用的是“上一輪”的舊值,避免當前輪更新的

?


lc442. 數組中重復的數據

模擬hash映射的原理? o(n)且不額外空間

“原地標記”

  • 壓榨完num的價值,數組自身的下標和符號 代替哈希表,num遍歷查看完一個元素后,還原地通過符號標記修改。
  • 利用了數也在1,n范圍的特性

找出數組里恰好出現兩次的數,返回這些數。

常規思路(哈希表,空間不夠好)

優化思路(原地標記,空間 O(1))

?

利用數組下標和元素值的特殊關系:

- 數組長度是 n,元素值范圍是 ?[1, n]?,下標范圍是 ?[0, n-1]?。

- 可以把下標和元素值對應起來(比如值為?num?的數,對應下標?num-1? ),通過改元素正負,標記這個數是否出現過。

?

具體步驟(遍歷+標記)

1.?遍歷數組,對當前數?num?:

- 先取絕對值(因為可能被改過符號),算對應下標 ?index = |num| - 1?;

- 看?nums[index]?的符號:

- 若為正:說明?num?是第一次出現,把?nums[index]?改成負數(標記“已訪問”);

- 若為負:說明?num?之前出現過,現在是第二次,把?num?加入結果(這就是重復的數)。

?

舉個例子

比如數組是 ?[4,3,2,7,8,2,3,1]?:

- 遍歷到?4?,對應下標?4-1=3?,?nums[3]?是?7?(正)→ 改成?-7?;

- 遍歷到?3?,對應下標?3-1=2?,?nums[2]?是?2?(正)→ 改成?-2?;

- ……

- 遍歷到?2?,對應下標?2-1=1?,?nums[1]?是?-3?(負)→ 說明?2?重復,加入結果;

- 最終找出所有重復兩次的數。

?

核心巧妙點

數組自身的下標和符號代替哈希表,不用額外空間,完美解決“找重復兩次的數”的問題,時間 O(n)、空間 O(1) 。

?

class Solution {
public:
vector<int> findDuplicates(vector<int>& nums) {
vector<int> duplicates;
int n = nums.size();
for (int i = 0; i < n; i++) {
int num = nums[i];
int index = abs(num) - 1;
? if (nums[index] > 0) {
nums[index] = -nums[index];

}

? ? ? ? ? else {
duplicates.push_back(index + 1);
}
}
return duplicates;
}
};

?

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

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

相關文章

react16-react19都更新哪些內容?

React 16 到 React 19 是 React 發展非常關鍵的階段&#xff0c;每個版本都帶來了深遠影響。以下是 React 16 → 19 的重要更新列表&#xff0c;按版本詳細說明每一代的核心特性、重要變化、對開發者的意義&#xff0c;并附簡評&#xff1a;? React 16&#xff08;2017 年&…

【AI大模型】RAG系統組件:向量數據庫(ChromaDB)

RAG 系統中的關鍵組件&#xff1a;向量數據庫&#xff08;Vector Database&#xff09;&#xff0c;并以 ChromaDB 為例進行說明。什么是向量數據庫&#xff1f;核心概念&#xff1a; 向量數據庫是一種專門設計用于高效存儲、索引和檢索高維向量的數據庫。向量是什么&#xff1…

006_測試評估與安全實踐

測試評估與安全實踐 目錄 建立成功標準評估方法測試策略安全最佳實踐隱私保護性能監控 建立成功標準 定義原則 1. 具體明確 清晰定義精確目標避免模糊表述如"良好性能"制定可操作的標準 不好的標準&#xff1a; 模型應該表現良好好的標準&#xff1a; 情感分…

時序預測 | Pytorch實現CNN-KAN電力負荷時間序列預測模型

預測效果 代碼功能 該代碼實現了一個結合卷積神經網絡&#xff08;CNN&#xff09;和Kolmogorov–Arnold網絡&#xff08;KAN&#xff09;的混合模型&#xff08;CNN-KAN&#xff09;&#xff0c;用于時間序列預測任務。核心功能包括&#xff1a; 數據加載與預處理&#xff1…

UI前端與數字孿生結合實踐探索:智慧物流的倉儲優化與管理系統

hello寶子們...我們是艾斯視覺擅長ui設計和前端數字孿生、大數據、三維建模、三維動畫10年經驗!希望我的分享能幫助到您!如需幫助可以評論關注私信我們一起探討!致敬感謝感恩!一、引言&#xff1a;倉儲管理的 “數字孿生革命”傳統物流倉儲正面臨 “效率瓶頸、可視化差、響應滯…

【Android】在平板上實現Rs485的數據通訊

前言 在工業控制領域&#xff0c;Android 設備通過 RS485 接口與 PLC&#xff08;可編程邏輯控制器&#xff09;通信是一種常見的技術方案。最近在實現一個項目需要和plc使用485進行通訊&#xff0c;記錄下實現的方式。 我這邊使用的從平的Android平板&#xff0c;從平里面已經…

MySQL技術筆記-備份與恢復完全指南

目錄 前言 一、備份概述 &#xff08;一&#xff09;備份方式 &#xff08;二&#xff09;備份策略 二、物理備份及恢復 &#xff08;一&#xff09;備份操作 &#xff08;二&#xff09;恢復操作 三、邏輯備份及恢復 &#xff08;一&#xff09;邏輯備份 &#xff0…

SpringBoot或OpenFeign中 Jackson 配置參數名蛇形、小駝峰、大駝峰、自定義命名

SpringBoot或OpenFeign中 Jackson 配置參數名蛇形、小駝峰、大駝峰、自定義命名 前言 在調用外部接口時&#xff0c;對方給出的接口文檔中&#xff0c;入參參數名一會大寫加下劃線&#xff0c;一會又是駝峰命名。 示例如下&#xff1a; {"MOF_DIV_CODE": "xx…

uni-app 途徑站點組件開發與實現分享

在移動應用開發中&#xff0c;涉及到出行、物流等場景時&#xff0c;途徑站點的展示是一個常見的需求。本文將為大家分享一個基于 uni-app 開發的途徑站點組件&#xff0c;該組件能夠清晰展示路線中的各個站點信息&#xff0c;包括站點名稱、到達時間、是否已到達等狀態&#x…

kotlin中集合的用法

從一個實際應用看起以下kotlin中代碼語法正確嗎 var testBeanAIP0200()var testList:List<AIP0200> ArrayList()testList.add(testBean)這段Kotlin代碼存在語法錯誤&#xff0c;主要問題在于&#xff1a;List<AIP0200> 是Kotlin中的不可變集合接口&#xff0c;不能…

深入理解 Java Map 與 Set

文章目錄前言1. 搜索樹1.1 什么是搜索樹1.2 查找1.3 插入1.4 刪除情況一&#xff1a;cur 沒有子節點&#xff08;即為葉子節點&#xff09;情況二&#xff1a;cur 只有一個子節點&#xff08;只有左子樹或右子樹&#xff09;情況三&#xff1a;cur 有兩個子節點&#xff08;左右…

excel如何只保留前幾行

方法一&#xff1a;手動刪除多余行 選中你想保留的最后一行的下一行&#xff08;比如你只保留前10行&#xff0c;那選第11行&#xff09;。按住 Shift Ctrl ↓&#xff08;Windows&#xff09;或 Shift Command ↓&#xff08;Mac&#xff09;&#xff0c;選中從第11行到最…

實時連接,精準監控:風丘科技數據遠程顯示方案提升試驗車隊管理效率

風丘科技推出的數據遠程實時顯示方案更好地滿足了客戶對于試驗車隊遠程實時監控的需求&#xff0c;并真正實現了試驗車隊的遠程管理。隨著新的數據記錄儀軟件IPEmotion RT和相應的跨平臺顯示解決方案的引入&#xff0c;讓我們的客戶端不僅可在線訪問記錄器系統狀態&#xff0c;…

灰盒級SOA測試工具Parasoft SOAtest重新定義端到端測試

還在為脆弱的測試環境、強外部依賴和低效的測試復用拖慢交付而頭疼&#xff1f;尤其在銀行、醫療、制造等關鍵領域&#xff0c;傳統的端到端測試常因環境不穩、接口難模擬、用例難共享而舉步維艱。 灰盒級SOA測試工具Parasoft SOAtest以可視化編排簡化復雜測試流程&#xff0c…

OKHttp 核心知識點詳解

OKHttp 核心知識點詳解 一、基本概念與架構 1. OKHttp 簡介 類型&#xff1a;高效的HTTP客戶端特點&#xff1a; 支持HTTP/2和SPDY&#xff08;多路復用&#xff09;連接池減少請求延遲透明的GZIP壓縮響應緩存自動恢復網絡故障2. 核心組件組件功能OkHttpClient客戶端入口&#…

從“被動巡檢”到“主動預警”:塔能物聯運維平臺重構路燈管理模式

從以往的‘被動巡檢’轉變至如今的‘主動預警’&#xff0c;塔能物聯運維平臺對路燈管理模式展開了重新構建。城市路燈屬于極為重要的市政基礎設施范疇&#xff0c;它的實際運行狀態和市民出行安全以及城市形象有著直接且緊密的關聯。不過呢&#xff0c;傳統的路燈管理模式當下…

10. 常見的 http 狀態碼有哪些

總結 1xx: 正在處理2xx: 成功3xx: 重定向&#xff0c;302 重定向&#xff0c;304 協商緩存4xx: 客戶端錯誤&#xff0c;401 未登錄&#xff0c;403 沒權限&#xff0c;404 資源不存在5xx: 服務器錯誤常見的 HTTP 狀態碼詳解 HTTP 狀態碼&#xff08;HTTP Status Code&#xff0…

springBoot對接第三方系統

yml文件 yun:ip: port: username: password: controller package com.ruoyi.web.controller.materials;import com.ruoyi.common.core.controller.BaseController; import com.ruoyi.common.core.domain.AjaxResult; import com.ruoyi.materials.service.IYunService; import o…

【PTA數據結構 | C語言版】車廂重排

本專欄持續輸出數據結構題目集&#xff0c;歡迎訂閱。 文章目錄題目代碼題目 一列掛有 n 節車廂&#xff08;編號從 1 到 n&#xff09;的貨運列車途徑 n 個車站&#xff0c;計劃在行車途中將各節車廂停放在不同的車站。假設 n 個車站的編號從 1 到 n&#xff0c;貨運列車按照…

量子計算能為我們做什么?

科技公司正斥資數十億美元投入量子計算領域&#xff0c;盡管這項技術距離實際應用還有數年時間。那么&#xff0c;未來的量子計算機將用于哪些方面&#xff1f;為何眾多專家堅信它們會帶來顛覆性變革&#xff1f; 自 20 世紀 80 年代起&#xff0c;打造一臺利用量子力學獨特性質…