欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

go語言題解LeetCode1160拼寫單詞示例詳解

 更新時間:2022年12月30日 09:07:02   作者:劉09k11  
這篇文章主要為大家介紹了go語言題解LeetCode1160拼寫單詞示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

題目描述

1160. 拼寫單詞 - 力扣(LeetCode)

給你一份『詞匯表』(字符串數組) words 和一張『字母表』(字符串) chars。

假如你可以用 chars 中的『字母』(字符)拼寫出 words 中的某個『單詞』(字符串),那么我們就認為你掌握了這個單詞。

注意:每次拼寫(指拼寫詞匯表中的一個單詞)時,chars 中的每個字母都只能用一次。

返回詞匯表 words 中你掌握的所有單詞的 長度之和。

示例 1:

輸入:words = ["cat","bt","hat","tree"], chars = "atach"
輸出:6
解釋: 
可以形成字符串 "cat" 和 "hat",所以答案是 3 + 3 = 6。

示例 2:

輸入:words = ["hello","world","leetcode"], chars = "welldonehoneyr"
輸出:10
解釋:
可以形成字符串 "hello" 和 "world",所以答案是 5 + 5 = 10。

提示:

1 <= words.length <= 1000

1 <= words[i].length, chars.length <= 100

所有字符串中都僅包含小寫英文字母

思路分析

先統(tǒng)計chars中各字母(字符)的個數

然后分別統(tǒng)計words字符串數組中的每個字符串的各個字母(字符)的個數

然后在26個對應位置作比較

若當前word字符串的對應位置字符數小于等于chars中對應位置字符數

則記錄當前word字符串的長度

將其做為總長度的一部分

依次比較余下的word字符串,重復前面操作,最終得到總長度(答案)

AC 代碼

class Solution {
    public int countCharacters(String[] words, String chars) {
        int n=chars.length();
        int[] arr=new int[26];
        for(int i=0;i<n;i++){
            arr[chars.charAt(i)-'a']++;
        }
        int res=0;
        for(String word:words){
            int[] arr1=new int[26];
            for(int j=0;j<word.length();j++){
                arr1[word.charAt(j)-'a']++;
            }
            for(int i=0;i<26;i++){
                if(arr1[i]<=arr[i]) {
                    if(i==25) res=res+word.length();
                }else break;
            }
        }
        return res;
    }
}

參考

 別人用int[26] 解題思路

友情提示:遇到有提示字符串僅包含小寫(或者大寫)英文字母的題,

都可以試著考慮能不能構造長度為26的每個元素分別代表一個字母的數組,來簡化計算

對于這道題,用數組c來保存字母表里每個字母出現(xiàn)的次數
如法炮制,再對詞匯表中的每個詞匯都做一數組w,比較數組w與數組c的對應位置

如果w中的都不大于c,就說明該詞可以被拼寫出,長度計入結果
如果w其中有一個超過了c,則說明不可以被拼寫,直接跳至下一個(這里用到了帶label的continue語法)

代碼

class Solution {
    public int countCharacters(String[] words, String chars) {
        int[] c = new int[26];
        for(char cc : chars.toCharArray()) {
            c[(int)(cc - 'a')] += 1;
        }
        int res = 0;
        a: for(String word : words) {
            int[] w = new int[26];
            for(char ww : word.toCharArray()) {
                w[(int)(ww - 'a')] += 1;
            }
            for(int i=0; i<26; i++) {
                if(w[i] > c[i]) {
                    continue a;
                }
            }
            res += word.length();
        }
        return res;
    }
}

c++幾乎雙百的哈希解法

解題思路

1 構建chars的字符到數量映射表

2. 對于words里的每個單詞也構建類似一個表,構建后去遍歷比較是否小于等于chars里的數量,否則失敗

代碼

class Solution {
public:
    int countCharacters(vector<string>& words, string chars) {
        // 記錄累計的長度之和
        int res = 0;
        // 構建chars的映射表
        int cnt[26];
        memset(cnt, 0, sizeof(int)*26);
        for (char c : chars)
        {
            ++cnt[c-'a'];
        }
???????        // 遍歷words去構建每個映射表,然后比較即可
        int curr[26];
        for (string word : words)
        {
            memset(curr, 0, sizeof(int)*26);
            for (char c : word)
            {
                ++curr[c-'a'];
            }
            bool IsOK= true;
            for (int i = 0; i < 26; ++i)
            {
                if (curr[i] > cnt[i])
                {
                    IsOK = false;
                    break;
                }
            }
            if (IsOK)
            {
                res += word.size();
            }
        }
        return res;
    }
};

以上就是go語言題解LeetCode1160拼寫單詞示例詳解的詳細內容,更多關于go題解拼寫單詞的資料請關注腳本之家其它相關文章!

相關文章

  • go高并發(fā)時append方法偶現(xiàn)錯誤解決分析

    go高并發(fā)時append方法偶現(xiàn)錯誤解決分析

    這篇文章主要為大家介紹了go高并發(fā)時append方法偶現(xiàn)錯誤解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • 通過Golang實現(xiàn)linux命令ls命令(命令行工具構建)

    通過Golang實現(xiàn)linux命令ls命令(命令行工具構建)

    這篇文章主要為大家詳細介紹了如何通過Golang實現(xiàn)一個linux命令ls命令(命令行工具構建),文中的示例代碼講解詳細,具有一定的學習價值,感興趣的可以了解一下
    2023-01-01
  • Go設計模式之備忘錄模式講解和代碼示例

    Go設計模式之備忘錄模式講解和代碼示例

    備忘錄是一種行為設計模式, 允許生成對象狀態(tài)的快照并在以后將其還原,本文就通過代碼示例給大家講講Go備忘錄模式,感興趣的小伙伴跟著小編一起來看看吧
    2023-08-08
  • Go語言中GORM存取數組/自定義類型數據

    Go語言中GORM存取數組/自定義類型數據

    在使用gorm時往往默認的數據類型不滿足我們的要求,需要使用一些自定義數據類型作為字段類型,下面這篇文章主要給大家介紹了關于Go語言中GORM存取數組/自定義類型數據的相關資料,需要的朋友可以參考下
    2023-01-01
  • Go 循環(huán)結構for循環(huán)使用教程全面講解

    Go 循環(huán)結構for循環(huán)使用教程全面講解

    這篇文章主要為大家介紹了Go 循環(huán)結構for循環(huán)使用全面講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • Go語言并發(fā)之原子操作詳解

    Go語言并發(fā)之原子操作詳解

    代碼中的加鎖操作因為涉及內核態(tài)的上下文切換會比較耗時、代價比較高。針對基本數據類型我們還可以使用原子操作來保證并發(fā)安全,本文就來和大家詳細聊聊,需要的可以參考下
    2022-12-12
  • 詳解go-zero如何實現(xiàn)計數器限流

    詳解go-zero如何實現(xiàn)計數器限流

    這篇文章主要來和大家說說限流,主要包括計數器限流算法以及具體的代碼實現(xiàn),文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-08-08
  • go的strings用法小結

    go的strings用法小結

    strings 是 Go 語言標準庫中提供的一個包,用于處理字符串相關的操作,本文主要介紹了go的strings用法小結,具有一定的參考價值,感興趣的可以了解一下
    2023-08-08
  • 使用GO操作MongoDB的方法

    使用GO操作MongoDB的方法

    這篇文章主要介紹了使用GO操作MongoDB,包括安裝MongoDB驅動程序連接mongodb的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • Golang實現(xiàn)Directional Channel(定向通道)

    Golang實現(xiàn)Directional Channel(定向通道)

    這篇文章主要介紹了Golang實現(xiàn)Directional Channel(定向通道),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02

最新評論