国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

Leetcode 203. Remove Linked List Elements

2019-11-09 21:03:46
字體:
來源:轉載
供稿:網友

Remove all elements from a linked list of integers that have value val.

Example Given: 1 –> 2 –> 6 –> 3 –> 4 –> 5 –> 6, val = 6 Return: 1 –> 2 –> 3 –> 4 –> 5

s思路: 1. 操作鏈表,要刪除數。首先想想鏈表的邊界是什么?左邊是頭節點,是邊界,右邊是為節點也是邊界。如果要刪除的節點恰好是頭節點,就要考慮頭指針改變的問題。因此用dummy或pointer-to-pointer。 2. 用dummy:首先需要新建一個node,賦初值為0,然后需要一個dummy指針指向這個node。 3. 用pointer-to-pointer: 之前總結過指向指針的指針的兩種操作:第一種是只移動指向指針的指針到新的位置,這個操作相當于站位,放到需要的地方,不對鏈表產生改變;第二種操作是修改被指針指向的指針里的地址,讓指針指向新的節點,這個操作會修改鏈表結構! 這里寫圖片描述 以上,Operation 1表示移動pointer-to-pointer指向不同節點的指針域,operation 2表示修改節點的指針域,讓指向新的node。這里最大的不同是,指針是低層次的,指向指針的指針是高層次的,更靈活,兩者不是一個級別的事物!如果鏈表操作中同時需要這兩個操作,就應該考慮用pointer-to-pointer

//方法1:dummy節點class Solution {public: ListNode* removeElements(ListNode* head, int val) { // ListNode node(0); ListNode* dummy=&node; dummy->next=head; head=dummy; while(head->next){ if(head->next->val==val){ head->next=head->next->next; }else head=head->next; } return node.next; }};//方法1.1:dummy節點,下面也行。但是需要delete dummy.不如上面方法來得快!class Solution {public: ListNode* removeElements(ListNode* head, int val) { // ListNode* dummy=new ListNode(0); dummy->next=head; head=dummy; while(head->next){ if(head->next->val==val){ head->next=head->next->next; }else head=head->next; } head=dummy->next; delete dummy; return head; }};//方法2:pointer-to-pointerclass Solution {public: ListNode* removeElements(ListNode* head, int val) { // ListNode** pp=&head; while(*pp){ if((*pp)->val==val){ *pp=(*pp)->next; }else pp=&((*pp)->next); } return head; }};
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 夏河县| 华容县| 隆回县| 耒阳市| 会理县| 基隆市| 保靖县| 永春县| 那坡县| 潜江市| 镇坪县| 湖州市| 仙游县| 鸡泽县| 古浪县| 舟曲县| 禹城市| 蒲江县| 大田县| 昭觉县| 新余市| 乌拉特中旗| 乐安县| 靖边县| 巴林左旗| 防城港市| 峨山| 铜山县| 赤水市| 精河县| 元阳县| 周至县| 台南市| 平和县| 前郭尔| 荥阳市| 平湖市| 滨州市| 淮北市| 沙坪坝区| 莫力|