java算法入門之有效的括號刪除有序數(shù)組中的重復(fù)項實現(xiàn)strStr
也許,我們永遠都不會知道自己能走到何方,遇見何人,最后會變成什么樣的人,但一定要記住,能讓自己登高的,永遠不是別人的肩膀,而是挑燈夜戰(zhàn)的自己,人生的道路剛剛啟程,當(dāng)你累了倦了也不要迷茫,回頭看一看,你早已不再是那個年少輕狂的少年。
1、LeetCode 20.有效的括號
題目
給定一個只包括 '(',')','{','}','[',']' 的字符串 s ,判斷字符串是否有效。
有效字符串需滿足:
左括號必須用相同類型的右括號閉合。
左括號必須以正確的順序閉合。
小編菜解
public static boolean isValid(String s) { if (s.length()%2 != 0) return false; Map<Character,Character> hashMap = new HashMap<Character,Character>(){{ put(')','('); put('}','{'); put(']','['); }}; //"{[]}" Queue<Character> queue = new LinkedList<Character>(); for (int i = 0; i < s.length(); i++) { char c = s.charAt(i); if(hashMap.containsKey(c)){ char t = queue.peek(); System.out.println(t);//這個地方彈出的是{ char tt = hashMap.get(c);//而這個對應(yīng)的是],,上一處peek應(yīng)該取得[ System.out.println(tt); System.out.println(queue.peek() != hashMap.get(c)); if (queue.isEmpty() || queue.peek() != hashMap.get(c)){ return false; } queue.poll(); }else{ queue.offer(c); } } return queue.isEmpty(); }
思路及算法
判斷括號的有效性可以使用「?!惯@一數(shù)據(jù)結(jié)構(gòu)來解決。
當(dāng)我們遇到一個右括號時,我們需要將一個相同類型的左括號閉合。此時,我們可以取出棧頂?shù)淖罄ㄌ柌⑴袛嗨鼈兪欠袷窍嗤愋偷睦ㄌ?。如果不是相同的類型,或者棧中并沒有左括號,那么字符串 ss 無效,返回 \text{False}False。為了快速判斷括號的類型,我們可以使用哈希表存儲每一種括號。哈希表的鍵為右括號,值為相同類型的左括號。
在遍歷結(jié)束后,如果棧中沒有左括號,說明我們將字符串 ss 中的所有左括號閉合,返回True,否則返回False。
注意到有效字符串的長度一定為偶數(shù),因此如果字符串的長度為奇數(shù),我們可以直接返回False,省去后續(xù)的遍歷判斷過程。
大神解法
public static boolean isValid(String s){ int n = s.length(); if (n % 2 == 1) { return false; } Map<Character, Character> pairs = new HashMap<Character, Character>() {{ put(')', '('); put(']', '['); put('}', '{'); }}; Deque<Character> stack = new LinkedList<Character>(); for (int i = 0; i < n; i++) { char ch = s.charAt(i); if (pairs.containsKey(ch)) { if (stack.isEmpty() || stack.peek() != pairs.get(ch)) { return false; } stack.pop(); } else { stack.push(ch); } } return stack.isEmpty(); }
思路和我的思路完全一致,就是我使用的是單向隊列,結(jié)果就是失敗,加油吧!
2、LeetCode 26.刪除有序數(shù)組中的重復(fù)項
題目
給你一個有序數(shù)組 nums ,請你 原地 刪除重復(fù)出現(xiàn)的元素,使每個元素 只出現(xiàn)一次 ,返回刪除后數(shù)組的新長度。
不要使用額外的數(shù)組空間,你必須在 原地 修改輸入數(shù)組 并在使用 O(1) 額外空間的條件下完成。
說明:
為什么返回數(shù)值是整數(shù),但輸出的答案是數(shù)組呢?
請注意,輸入數(shù)組是以「引用」方式傳遞的,這意味著在函數(shù)里修改輸入數(shù)組對于調(diào)用者是可見的。
小編菜解初版
public static Integer[] removeDuplicates(Integer[] nums) { if(nums == null || nums.length == 0){ return nums; } List<Integer> tempList = Arrays.asList(nums); for (int i = tempList.size() - 1; i >= 0; i--) { Integer current = tempList.get(i); if(i-1>0){ Integer next = tempList.get(i - 1); if(next == current){ tempList.remove(current); } } } Integer[] ret = new Integer[tempList.size()]; tempList.toArray(ret); return ret; }
為什么為這樣呢?我記得list是可以remove的啊,百思不得其解,查一下源碼,猛然發(fā)現(xiàn)
Arrays的內(nèi)部類ArrayList和java.util.ArrayList都是繼承AbstractList,remove、add等方法在AbstractList中是默認(rèn)throw UnsupportedOperationException而且不作任何操作。java.util.ArrayList重寫這些方法而Arrays的內(nèi)部類ArrayList沒有重寫,所以會拋出異常。
小編菜解改進版
public static Integer[] removeDuplicates(Integer[] nums) { if(nums == null || nums.length == 0){ return nums; } List<Integer> tempList = Arrays.asList(nums); List<Integer> list = new ArrayList<>(tempList); for (int i = list.size() - 1; i >= 0; i--) { Integer current = list.get(i); if(i-1>0){ Integer next = list.get(i - 1); if(next == current){ list.remove(current); } } } Integer[] ret = new Integer[list.size()]; list.toArray(ret); return ret; }
不報錯了,結(jié)果也對,perfect!
思路及算法
相等的元素在數(shù)組中的下標(biāo)一定是連續(xù)的。利用數(shù)組有序的特點,可以通過雙指針的方法刪除重復(fù)元素。
大神解法
public static int removeDuplicates2(Integer[] nums) { int n = nums.length; if (n == 0) { return 0; } int fast = 1, slow = 1; while (fast < n) { if (nums[fast] != nums[fast - 1]) { nums[slow] = nums[fast]; ++slow; } ++fast; } return slow; }
我去,無情。我的解法果然很菜,題意都沒讀懂,人家要的是長度,你返回一個數(shù)組,作甚??
3、LeetCode 28.實現(xiàn)strStr
題目
實現(xiàn) strStr() 函數(shù)。
給你兩個字符串 haystack 和 needle ,請你在 haystack 字符串中找出 needle 字符串出現(xiàn)的第一個位置(下標(biāo)從 0 開始)。如果不存在,則返回 -1 。
說明:
當(dāng) needle 是空字符串時,我們應(yīng)當(dāng)返回什么值呢?這是一個在面試中很好的問題。
對于本題而言,當(dāng) needle 是空字符串時我們應(yīng)當(dāng)返回 0 。這與 C 語言的 strstr() 以及 Java 的 indexOf() 定義相符。
小編菜解
public static int strStr(String haystack, String needle) { if(haystack == null || !haystack.contains(needle)){ return -1; } if(needle == ""){ return 0; } int strLg = haystack.length(); int findLg = needle.length(); for (int i = 0; i < strLg; i++) { char c = haystack.charAt(i); if (c == needle.charAt(0) && i+findLg <= strLg){ String temp = haystack.substring(i,i + findLg); if (temp.equals(needle)){ return i; } } } return -1; }
沒看出有什么問題,可是提交總是提示解答錯誤,也是無奈。
大神解法
public static int strStr(String haystack, String needle) { int strLg = haystack.length(); int findLg = needle.length(); for (int i = 0; i+findLg <= strLg; i++) { boolean flag = true; for (int j = 0; j < findLg; j++) { if (haystack.charAt(i+j)!=needle.charAt(j)){ flag = false; break; } } if (true == flag){ return i; } } return -1; }
感覺大神的解法還沒我的解法簡單呢?可我的為何一直提交都是出錯,哎,無奈。
到此這篇關(guān)于java算法入門之有效的括號刪除有序數(shù)組中的重復(fù)項實現(xiàn)strStr的文章就介紹到這了,更多相關(guān)Java算法strStr內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JAVA8 List<List<Integer>> list中再裝一個list轉(zhuǎn)成一個list操
這篇文章主要介紹了JAVA8 List<List<Integer>> list中再裝一個list轉(zhuǎn)成一個list操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08Java利用Netty時間輪實現(xiàn)延時任務(wù)
時間輪是一種可以執(zhí)行定時任務(wù)的數(shù)據(jù)結(jié)構(gòu)和算法。本文將為大家詳細講解一下Java如何利用Netty時間輪算法實現(xiàn)延時任務(wù),感興趣的小伙伴可以了解一下2022-08-08SpringBoot與velocity的結(jié)合的示例代碼
本篇文章主要介紹了SpringBoot與velocity的結(jié)合的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03Java8的default和static關(guān)鍵字的使用講解
今天小編就為大家分享一篇關(guān)于Java8的default和static關(guān)鍵字的使用講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-01-01startJVM錯誤Unable to load native library: libjvm.so解決方法
這篇文章主要介紹了startJVM錯誤Unable to load native library: libjvm.so解決方法,需要的朋友可以參考下2014-07-07給Java菜鳥的一些建議_關(guān)于Java知識點歸納(J2EE and Web 部分)
下面小編就為大家?guī)硪黄oJava菜鳥的一些建議_關(guān)于Java知識點歸納(J2EE and Web 部分)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05