国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

49. Group Anagrams and 249. Group Shifted Strings

cppowboy / 2235人閱讀

摘要:也就是同構(gòu)異形體。特點(diǎn)是有相同數(shù)量的組成。素?cái)?shù)可以素?cái)?shù)表。這里使用而不是可以避免最后從導(dǎo)出結(jié)果的時(shí)間。修改了和得到的方法,其他都一樣。但是會(huì)有解不了的地方。還有個(gè)特殊情況就是不是一組。如果數(shù)字編碼出來都是如果用編碼,出現(xiàn)的就是。

49 Group Anagrams

Given an array of strings, group anagrams together.
For example, given: ["eat", "tea", "tan", "ate", "nat", "bat"], 
Return:
[
  ["ate", "eat","tea"],
  ["nat","tan"],
  ["bat"]
]
Anagrams也就是同構(gòu)異形體。特點(diǎn)是string有相同數(shù)量的char組成。
有兩種方法,一直是把每個(gè)單詞sort, 相同的anagrams肯定擁有同樣的key. 時(shí)間復(fù)雜度O(klogk).
另一種方法,利用素?cái)?shù)相乘,26個(gè)字母對(duì)應(yīng)最小的26個(gè)素?cái)?shù),一個(gè)anagrams有唯一的key. 時(shí)間復(fù)雜度O(k).

1 素?cái)?shù)相乘得到key。 (素?cái)?shù)可以google素?cái)?shù)表。)

public class Solution {
    public List> groupAnagrams(String[] strs) {
        int[] primes = {2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101};
        
        List> res = new ArrayList>();
        HashMap map = new HashMap<>();   // key, position in array
        // 這里使用HashMap 而不是 HashMap> 可以避免最后從Map導(dǎo)出結(jié)果的時(shí)間。
        for(String str:strs){
            int key = 1;
            for(char c: str.toCharArray()){
                key *= primes[c-"a"];
            }
            List t;
            if(map.containsKey(key)){
                t = res.get(map.get(key));
            } else {
                t = new ArrayList();
                map.put(key, res.size());
                res.add(t);
            }
            t.add(str);
        }
        return res;
    }
}

2 sort

public class Solution {
    public List> groupAnagrams(String[] strs) {
        List> res = new ArrayList>();
        HashMap map = new HashMap<>();   // key, position in array
        
        for(String str:strs){
            // 修改了hashmap和得到Key的方法, 其他都一樣。
            char[] c = str.toCharArray();
            Arrays.sort(c);
            String key = String.valueOf(c);
            List t;
            if(map.containsKey(key)){
                t = res.get(map.get(key));
            } else {
                t = new ArrayList();
                map.put(key, res.size());
                res.add(t);
            }
            t.add(str);
        }
        return res;
    }
}

249 Group Shifted Strings

For example, given: ["abc", "bcd", "acef", "xyz", "az", "ba", "a", "z"], 
A solution is:
[
  ["abc","bcd","xyz"],
  ["az","ba"],
  ["acef"],
  ["a","z"]
]
拿"abc","bcd","xyz"這組舉例子。 
"abc": "b"-"a" = 1, "c"-"a" = 2,  012
"bcd": "c"-"b" = 1, "d"-"c" = 2,  012
"xyz": "y"-"x" = 1, "z"-"x" = 2,  012
如果用數(shù)字做Key,上面都是12。但是會(huì)有解不了的地方。
還有個(gè)特殊情況就是"a", "aa", "aaa"不是一組。如果數(shù)字編碼出來都是0.
如果用string編碼,出現(xiàn)的就是0, 00, 000。就可以區(qū)分了。
public class Solution {
    public List> groupStrings(String[] strings) {
        HashMap> map = new HashMap<>();
        
        for(String s: strings){
            String key = getKey(s);
            List value = map.get(key);
            if(value == null){
                value = new ArrayList<>();
                map.put(key, value);
            }
            value.add(s);
        }
        
        List> res = new ArrayList<>();
        for(List list: map.values()){
            Collections.sort(list); // dont forget to sort.
            res.add(list);
        }
        
        return res;
    }
    
    private String getKey(String s){
        int[] arr = new int[s.length()];
        for(int i = 1; i < s.length(); i++){
            arr[i] = s.charAt(i)-s.charAt(0) < 0? 
                     (s.charAt(i)-s.charAt(0) + 26): (s.charAt(i)-s.charAt(0));
        }
        return Arrays.toString(arr);
    }
}

288 Unique Word Abbreviation

a) it                      --> it    (no abbreviation)

     1
b) d|o|g                   --> d1g

              1    1  1
     1---5----0----5--8
c) i|nternationalizatio|n  --> i18n

              1
     1---5----0
d) l|ocalizatio|n          --> l10n
public class ValidWordAbbr {
    HashMap map;
    
    public ValidWordAbbr(String[] dictionary) {
        map = new HashMap<>();
        for(String word : dictionary){
            String key = getKey(word);
            if(map.containsKey(key)){
                if(!map.get(key).equals(word)){
                    map.put(key, "");
                }
            } else {
                map.put(key, word);
            }
        }
        
    }
    
    public boolean isUnique(String word) {
        String key = getKey(word);
        return !map.containsKey(key) || map.get(key).equals(word);
    }
    
    public String getKey(String word){
        if(word.length() <= 2) return word;
        return word.charAt(0) + Integer.toString(word.length()-2) + word.charAt(word.length()-1);
    }
}

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/66925.html

相關(guān)文章

  • 249. Group Shifted String

    摘要:題目解答在為負(fù)數(shù)的時(shí)候,當(dāng)經(jīng)過的時(shí)候,數(shù)值大小會(huì)很大得反轉(zhuǎn) 題目:Given a string, we can shift each of its letter to its successive letter, for example: abc -> bcd. We can keep shifting which forms the sequence: abc -> bcd -> ....

    JerryZou 評(píng)論0 收藏0
  • 49. Group Anagrams

    摘要:題目解答遇到這種要求一個(gè)的集合,首先想到的就是。那么被的作為把有同樣的以的形式放到里,然后輸出。 題目:Given an array of strings, group anagrams together. For example, given: [eat, tea, tan, ate, nat, bat], Return: [ [ate, eat,tea], [nat,tan],...

    wangtdgoodluck 評(píng)論0 收藏0
  • leetcode 49 Group Anagrams

    摘要:不需要關(guān)注輸出的順序,所有的輸入都是小寫。的就是經(jīng)過排序后的字符數(shù)組所對(duì)應(yīng)的字符串。因?yàn)椴恍枰紤]輸出的順序,所以遍歷完直接輸出中的所有值即可。解法邊界情況判斷如果存在相同組成的元素 題目詳情 Given an array of strings, group anagrams together.題目要求輸入一個(gè)字符串?dāng)?shù)組,我們要將由同樣字母組成的字符串整理到一起,然后以如下例子中的格式...

    陳偉 評(píng)論0 收藏0
  • leetcode49 Group Anagrams

    摘要:同時(shí)使用方法將數(shù)組轉(zhuǎn)化為并利用的直接比較兩個(gè)字符串是否相等。通過這種方法效率值提高了不少。 題目要求 Given an array of strings, group anagrams together. For example, given: [eat, tea, tan, ate, nat, bat], Return: [ [ate, eat,tea], [nat,t...

    sunsmell 評(píng)論0 收藏0
  • [Leetcode] Group Anagrams 變形詞

    摘要:我們將每個(gè)詞排序后,根據(jù)這個(gè)鍵值,找到哈希表中相應(yīng)的列表,并添加進(jìn)去。 Group Anagrams 最新更新請(qǐng)見:https://yanjia.me/zh/2019/01/... Given an array of strings, group anagrams together. For example, given: [eat, tea, tan, ate, nat, bat...

    Lin_YT 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<