有效的 Anagram | Easy |LeetCode#242 Valid Anagram
題目敘述
題目難度: Easy
題目敘述: 題目要求給定兩個字串 s 與 t,若 t 為 s 的 Anagram,則回傳 true,若不是則回傳 false
Anagram 代表兩個單字裡面組成的字母和數量是完全一樣的,簡單來說 Anagram 就是由A單字重新排列組合成一個B單字。
解法一開始的想法這次的想法一樣是建立 HashTable,所以一開始的想法如下:
迭代 s,建立 HashTable
迭代 t,依序檢查字母是否有出現在 HashTable,進行比對
迭代完畢後,若全部匹配則回傳True
若無則否
我的解法1234567891011121314151617181920212223242526272829303132333435363738class Solution {public: bool isAnagram(string s, string ...
整數到羅馬數字 | Medium |LeetCode#12 Integer to Roman
題目敘述
題目難度:Medium
題目敘述:題目主要需求是將輸入的整數 num 轉換成對應的羅馬數字符號,並給定一個對應表,在轉換過程有幾項轉換規則:
羅馬數字是通過從最高位到最低位將小數位值的轉換連接起來形成的
如果該值不以4或9開頭,則選擇可以從輸入中減去的最大值的符號,將該符號附加到結果中,減去其值,然後將剩餘部分轉換為羅馬數字。
如果該值以4或9開頭,則使用表示從下一個符號中減去一個符號的減法形式,例如,4是 5(V)減去1(I):IV,而9是10(X)減去1(I):IX。只使用以下減法形式:4(IV)、9(IX)、40(XL)、90(XC)、400(CD)和900(CM)。
只有10的次方(I、X、C、M)可以最多連續附加3次以表示10的倍數。不能多次附加5(V)、50(L)或500(D)。如果需要附加4次符號,需使用減法形式
限制: 1 <= num <= 3 ...
C++ 刷題利器 - STL (Standard Template Library) | LeetCode
這篇主要是來記錄學習STL,並且在刷題過程中方便查找好用的STL的筆記
奇偶數鏈節串列 | Medium | LeetCode#328 Odd Even Linked List
題目敘述
題目難度: Medium
題目敘述: 給定一個 single linked list 的 head,將所有具有奇數索引的節點分組在一起,然後將具有偶數索引的節點分組,並傳回重新排序的list。第一個節點為奇數索引,接著第二個為偶數,以此類推,此題要求實作的演算法空間複雜度為 $O(1)$ 而時間複雜度為 $O(n)$
解法一開始的想法
我的想法就是先traverse list,然後紀錄偶數節點個數和奇數節點個數,之後各自建立新的lists,最後合併兩個lists然後回傳薪的head
我的解法12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 ...
尋找插入位置 | Easy | LeetCode#35 Search Insert Position
題目敘述
題目難度: Easy
題目敘述: 給定已排序的整數陣列,以及一個目標值,若再陣列中找到目標值就返回 index,如果沒有就返回適合插入的位址。另外題目也要求實作演算法的複雜度要是 $O(log n)$。
解法一開始的想法
針對已排序的陣列,尋找目標值的方法使用 Binary Search 可以滿足需求
我的解法123456789101112131415161718192021222324252627282930int searchInsert(int* nums, int numsSize, int target) { int right, left, mid; right = numsSize-1; left = 0; while(left < right){ mid = left + (right - ...
找到鏈結串列的中間節點 | Easy |LeetCode#876 Middle of the Linked List
題目敘述
題目難度: Easy
題目敘述: 給定一個 single linked list 的 head 並且希望回傳 list 的中間節點,若中間節點有兩個,需要回傳第二個
解法一開始的想法
定義節點結構
建立 linked list
呼叫函數 middleNode()
在 middleNode 內:
Traverse list,才有辦法知道中間節點,在 traverse過程透過一個counter來紀錄數量
判斷當前節點數量是奇數還是偶數,取得中間節點的 index
接著重新走訪到 middleNode,並回傳節點
我的解法1234567891011121314151617181920212223242526272829303132333435363738394041/** * Definition for singly-linked list. * struct List ...
合併鏈結串列 | Easy | LeetCode#21 Merge Two Sorted Lists
題目敘述
題目難度: Easy
題目描述: 給定兩個已排序 linked list 的 head,希望能夠合併成一個已排序的list
解法一開始的想法
一開始我想說可以先走訪 list1 然後逐項比對 list2 的item,如果 list1中的元素小於 list2 的,就插入到 list2,並且插入後,再繼續迭代 list1當中的元素
原始代碼:
1234567891011121314151617181920212223242526272829303132333435363738394041424344Node *ptr1, *ptr2, *previous, *preceding; ptr1 = list1;ptr2 = list2;preceding = ptr1;previous = ptr2;//Empty listsif(ptr1==NULL && ptr2 ...
反向鏈結串列 | Easy |LeetCode#206 Reverse Linked List
題目敘述
題目難度: Easy
題目描述: 給定一個 linked list 的 head,希望整個 list 反轉,並且回傳反轉後的list
解法一開始的想法123456789101. 定義節點結構2. 建立 linked list3. reverseList()4. 建立暫存節點,用來存放下一個節點的位址,也需要站存上一個節點的位址4-1. 將下一個節點的位址鏈結到上一個節點4-2. 更新暫時存節點4-3 . 更新前一個節點4-4. 移動至下一個節點5. 更新初始節點指標6. 回傳初始節點指標
後來我發現 head 跟tail 其實可以不用各別分開處理
我的解法1234567891011121314151617181920/** * Definition for singly-linked list. * struct ListNode { * int ...
鏈結串列刪除元素 | Easy |LeetCode#203 Remove Linked List Elements
題目敘述
題目難度: Easy
題目描述: 給定一個 Linked List 的 head 以及想要刪除節點的數值 val,要我們移除list中所有等於 val 的節點,所以如果所有節點數值都等於 val 則結果會是一個 emptt list
解法一開始的想法123456781. 定義節點結構2. 建立 linked list3. removeElements3-1. 宣告暫存空間3-2 判斷是否是 Empty List3-3. 走訪整個List3-4. 判斷是否等於 val,如果等於:那就將前一個節點連接到後一個節點,並釋放記憶體以刪除 val 所在節點3-5 回傳head
這是看到題目後一開始的主要想法,並且一開始很天真的想說還需要考慮刪除節點在 Head, 中間 以及 Tail 三種狀況,實作後才發現其實只需要判斷頭跟其他地方就好,Tail 應該不用單獨拿出來處理。
我的 ...
刪除鏈結串列 | Medium | LeetCode#237 Delete Node in a Linked List
題目敘述
題目難度: Medium
題目描述: 如同圖中所述,題目中要求我們對一個 Single Linked List head 去實現一個刪除特定節點的函式,函式的輸入叫做 node,題目中有特別說明。
限制:
node 不會是 head中的最後一個節點,並且我們並不能夠存取 head 中的第一個元素,也就是整個 List 的初始節點。
這題的刪除節點不需要釋放記憶體,僅需將前一個節點連接到 node 的後一個節點
在 Run 以及 Submit 的時候,題目會建好List 並且呼叫我們寫的function,來去進行測試,這題只需要專注在刪除節點的邏輯上就好
解法一開始的想法一開始我陷入了傳統刪除節點的做法當中,也就是已知初始節點的條件下去走訪每個節點,指到找到給定節點,再去執行刪除的邏輯。
傳統作法12345678910111213141516171819202122 ...