每日一題(LeetCode)----鏈表--分隔鏈表

每日一題(LeetCode)----鏈表–分隔鏈表

1.題目(86. 分隔鏈表)

給你一個鏈表的頭節點 head 和一個特定值 x ,請你對鏈表進行分隔,使得所有 小于 x 的節點都出現在 大于或等于 x 的節點之前。

你應當 保留 兩個分區中每個節點的初始相對位置。

示例 1:

img

輸入:head = [1,4,3,2,5,2], x = 3
輸出:[1,2,2,4,3,5]

示例 2:

輸入:head = [2,1], x = 2
輸出:[1,2]

提示:

  • 鏈表中節點的數目在范圍 [0, 200]
  • -100 <= Node.val <= 100
  • -200 <= x <= 200

2.解題思路

思路一

將這個鏈表進行拆分,然后合并
1.拆分

把比目標值小的節點存一個鏈表里,把比目標值大的節點另一個鏈表里

2.合并

把存比目標值大的節點的鏈表接到存比目標值小的節點的鏈表的后面

思路二:快排的思想:區間分割法
1.申請一個虛擬節點,且這個虛擬節點指向頭節點,然后這個虛擬節點作為小區間(比目標值小的節點的空間)的尾節點
2.遍歷鏈表進行節點的改變來得到所要的答案鏈表
遍歷鏈表,看當前鏈表中的值是否小于目標值

如果大于,那么pre指向當前節點,然后繼續遍歷

如果小于,那么看pre所指向的節點是否是小區間的尾節點

如果是,那么pre指向當前節點,然后繼續遍歷

如果不是 ,(1)我們讓pre指向的那個節點的下一個節點變為為當前節點的下一個節點

? (2)當前節點指向小區間尾節點的下一個節點,然后小區間的尾節點再指向當節點 (3)小區間的尾節點向后移動一個節點,下一次要遍歷的節點為pre所指向節點的下一個節點

3.寫出代碼

思路一的代碼
class Solution {
public:ListNode* partition(ListNode* head, int x) {if(head==nullptr||head->next==nullptr){return head;}//遍歷一遍鏈表拆成兩個鏈表ListNode* head1=nullptr;ListNode* head2=nullptr;ListNode* tail1=nullptr;ListNode* tail2=nullptr;while(head){if(head->val<x){if(head1==nullptr){head1=tail1=head;}else{tail1->next=head;tail1=tail1->next;}}else{if(head2==nullptr){head2=tail2=head;}else{tail2->next=head;tail2=tail2->next;}}head=head->next;}if(tail1){tail1->next=nullptr;}if(tail2){tail2->next=nullptr;}if(tail1){tail1->next=head2;return head1;}else{return head2;}}
};
思路二的代碼
class Solution {
public:ListNode* partition(ListNode* head, int x) {if(head ==nullptr || head->next==nullptr){return head;}ListNode* dummyhead = new ListNode(0,head);ListNode* prevtail = dummyhead,*prev = dummyhead,*curr = head;while(curr){if(curr->val < x){if(prev != prevtail){prev->next = curr->next;curr->next = prevtail->next;prevtail->next = curr;prevtail = prevtail->next;curr = prev->next;}else{prev = prevtail = curr;curr = curr->next;}  }else{prev = curr;curr = curr->next;}}return dummyhead->next;}
};

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

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

相關文章

關于LORA的優勢以及常見應用產品領域

lora的優勢&#xff1a; 1 低功耗 2 傳輸距離遠 3 信號穿透性好 4 靈敏度高&#xff0c;適合可靠性要求高的領域 5 低成本 Lora 產品領域 &#xff1a; 一、智慧城市 1 智能停車&#xff1a;在較大的停車場&#xff0c;通過Lora技術&#xff0c;采集車位信息&#xff0…

問題解決:Ubuntu18.04下nvcc -V指令可用,/usr/local/下卻沒有cuda文件夾,原因分析及卸載方法

問題描述 今天要運行一個程序&#xff0c;需要CUDA版本高于10.0&#xff0c;我的電腦無法運行&#xff0c;于是開始檢查 首先使用nvidia-smi與nvcc -V指令 能夠看出來&#xff0c;當前顯卡驅動適合的CUDA版本為12.1&#xff0c;而本機安裝的版本是9.1.85&#xff0c;那么就需…

實驗7設計建模工具的使用(三)

二&#xff0c;實驗內容與步驟 1. 百度搜索1-2張狀態圖&#xff0c;請重新繪制它們&#xff0c;并回答以下問題&#xff1a; 1&#xff09;有哪些狀態&#xff1b; 2&#xff09;簡要描述該圖所表達的含義&#xff1b; 要求&#xff1a;所繪制的圖不得與本文中其它習題一樣…

有一臺電腦一部手機就可以在網上賺錢,這些項目你也可以學會

很多人都希望能夠在家中或者閑暇的時候&#xff0c;能夠在網上賺錢&#xff0c;而網絡給了我們這樣的可能。只要有一臺電腦和一部手機&#xff0c;你就可以開始你的賺錢之旅。這些項目并不難&#xff0c;只要你肯學&#xff0c;就一定能夠成功。 1、美工設計 這個副業主要是推薦…

【STL】string類(中)

目錄 1&#xff0c;rbegin 和 rend 2&#xff0c;reserve & capacity 3&#xff0c;max_size ( ) 4&#xff0c;size&#xff08;&#xff09;& resize 1&#xff0c;void resize (size_t&#xff0c;char c&#xff09; 5&#xff0c;push_back & append 1…

城市生命線丨橋梁健康結構監測系統作用如何

截至2022年底&#xff0c;我國擁有公路橋梁103.3萬座&#xff0c;總長約8576萬延米&#xff0c;其中特大橋8816座&#xff0c;總長約1621萬延米。 為了確保這些橋梁的安全&#xff0c;需要進行定期的檢測和維護&#xff0c;及時發現和解決橋梁存在的問題。 同時&#xff0c;政…

Servlet---HttpServlet、HttpServletRequest、HttpServletResponseAPI詳解

文章目錄 HttpServlet基礎方法doXXX方法Servlet的生命周期 HttpServletRequest獲取請求中的信息獲取請求傳遞的參數獲取 query string 里的數據獲取form表單里的數據獲取JSON里的數據如何解析JSON格式獲取數據返回數據 HttpServletResponse設置響應的Header設置不同的狀態碼設置…

ASM之ClassWriter生成.class

ASM之ClassWriter生成.class 我們可以使用ClassWriter來生成一個類 如果不知道如何編寫ASMified代碼&#xff0c;可以直接使用插件ASMPlugin&#xff0c;將你需要的功能編寫成正常的java代碼&#xff0c;然后使用ASM Bytecode Viewer將編寫的類轉換成ASMified代碼后作為參考 …

瀏覽器事件循環原理 —— 任務優先級

系列文章目錄 第一章 瀏覽器事件循環原理 —— 瀏覽器進程模型第二章 瀏覽器事件循環原理 —— 渲染主線程如何工作&#xff1f;第三章 瀏覽器事件循環原理 —— 何為異步&#xff1f;第四章 瀏覽器事件循環原理 —— JS為何會阻礙渲染&#xff1f; 文章目錄 系列文章目錄 文…

C/C++雜談-printf的可變參數機制

C/C雜談-printf的可變參數機制 文章目錄 C/C雜談-printf的可變參數機制printf的使用printf的源碼源碼剖析 多參數實現機制原理 C11引入了可變參數模板機制&#xff0c;對模板參數進行了高度泛化&#xff0c;但是對于可變參數其實C語言學習中早已遇到過&#xff0c;那就是printf…

【Redis】持久化-RDBAOF混合持久化

文章目錄 前置知識RDB&#xff08;定期備份&#xff09;觸發機制流程說明RDB文件的處理RDB 的優缺點 AOF&#xff08;實時備份&#xff09;使用AOF命令寫入AOF工作流程文件同步重寫機制重寫觸發機制AOF進制重寫流程 混合持久化啟動時數據恢復 總結 前置知識 回顧MySQL MySQL的事…

LeetCode(28)盛最多水的容器【雙指針】【中等】

目錄 1.題目2.答案3.提交結果截圖 鏈接&#xff1a; 盛最多水的容器 1.題目 給定一個長度為 n 的整數數組 height 。有 n 條垂線&#xff0c;第 i 條線的兩個端點是 (i, 0) 和 (i, height[i]) 。 找出其中的兩條線&#xff0c;使得它們與 x 軸共同構成的容器可以容納最多的水…

云計算時代改變了什么?

當今云計算時代&#xff0c;計算資源和數據存儲已經不再受限于本地設備的硬件和軟件限制。云計算技術的發展和普及&#xff0c;使得用戶可以通過互聯網訪問大量的計算資源和存儲空間&#xff0c;從而改變了我們對計算和數據的看法。本文將探討云計算時代對計算和數據處理的影響…

對線程的創建

一&#xff0c;概括 二&#xff0c;線程構建方式一&#xff08;繼承Thread類&#xff09; 三&#xff0c;案例 父類&#xff1a; package Duoxiancheng;public abstract class Name {public static void main(String[] args) {//3&#xff0c;創建一個Thread線程類對象Thr…

匯編語言學習筆記

匯編語言的不同種類 as86匯編&#xff1a;能產生16位代碼的Intel 8086匯編 mov ax, cs //cs→ax&#xff0c;目標操作數在前GNU as匯編&#xff1a;產生32位代碼&#xff0c;使用AT&T系統V語法 movl var&#xff0c; %eax // var→%eax&#xff0c;目標操作數在后內嵌匯編…

Android異步之旅:探索AsyncTask

前言&#xff1a; 在Android應用程序開發中&#xff0c;異步操作是非常常見的需求。比如&#xff0c;我們可能需要在后臺線程中執行網絡請求、數據庫操作或者其他耗時的任務&#xff0c;而不阻塞UI線程。為了實現這些異步操作&#xff0c;Android提供了多種方式&#xff0c;其…

基于Qt的UDP通信、TCP文件傳輸程序的設計與實現——QQ聊天群聊

&#x1f64c;秋名山碼民的主頁 &#x1f602;oi退役選手&#xff0c;Java、大數據、單片機、IoT均有所涉獵&#xff0c;熱愛技術&#xff0c;技術無罪 &#x1f389;歡迎關注&#x1f50e;點贊&#x1f44d;收藏??留言&#x1f4dd; 獲取源碼&#xff0c;添加WX 目錄 前言一…

PostgreSQL序列,怎么才能第二天重新從1開始計數

--確定日期最大值和每天序列號最大值 with cte as(select (((1::bigint)<<32)-1) as max_date_second,(((1::bigint)<<31)-1) as max_sn )select max_date_second,to_timestamp(max_date_second),max_sn,((max_date_second<<31)|max_sn) as max_val,(((max_d…

Selenium 元素不能定位總結

目錄 元素不能定位總結: 1、定位語法錯誤&#xff1a; 定位語法錯誤&#xff0c;如無效的xpath&#xff0c;css selector,dom路徑錯誤&#xff0c;動態dom 定位語法錯誤&#xff0c;動態路徑&#xff08;動態變化&#xff09; 定位策略錯誤&#xff0c;如dom沒有id用id定位…

研發探索:導購APP、查券返利機器人與淘客系統,全面對比與選擇

研發探究&#xff1a;導購APP、查券返利機器人與淘客系統&#xff0c;全面對比與選擇 在互聯網購物的時代&#xff0c;導購APP、淘客機器人和微賺淘客系統成為了消費者們的三大好幫手。它們各具優勢&#xff0c;但也存在一些不足。本文將為您詳細對比這三種工具&#xff0c;幫…