成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

leetcode每日一題-423:從英文中重建數(shù)字

kyanag / 2659人閱讀

摘要:每日一題從英文中重建數(shù)字鏈接從英文中重建數(shù)字題目分析首先我們先分析每個字母的組成,然后發(fā)現(xiàn)一些字符只在一個單詞中出現(xiàn),我們先去統(tǒng)計一下這些單詞個數(shù)。統(tǒng)計完次數(shù),按升序排列即可。

leetcode每日一題-423:從英文中重建數(shù)字

鏈接

從英文中重建數(shù)字


題目



分析



首先我們先分析每個字母的組成,然后發(fā)現(xiàn)一些字符只在一個單詞中出現(xiàn),我們先去統(tǒng)計一下這些單詞個數(shù)。

z,w,u,x,g都只出現(xiàn)在一個數(shù)字中,也就是0,2,4,6,8,我們用哈希表統(tǒng)計一下s字符串中各個字符的數(shù)量,就可以知道0,2,4,6,8的數(shù)量,然后我們注意一下只在兩個數(shù)字中出現(xiàn)的字符。

  • h 只在 3,8 中出現(xiàn)。由于我們已經(jīng)知道了 8 出現(xiàn)的次數(shù),因此可以計算出 3 出現(xiàn)的次數(shù)。
  • f 只在 4,5 中出現(xiàn)。由于我們已經(jīng)知道了 4 出現(xiàn)的次數(shù),因此可以計算出 5 出現(xiàn)的次數(shù)。
  • s 只在 6,7 中出現(xiàn)。由于我們已經(jīng)知道了 6 出現(xiàn)的次數(shù),因此可以計算出 7 出現(xiàn)的次數(shù)。

此時,只剩下1和9還不知道,但是字符含有o的其他數(shù)字我們都已經(jīng)知道了,那么剩下的數(shù)量就是1的數(shù)量。

然后此時含有i的就只有9了,統(tǒng)計一下9的數(shù)量即可。

統(tǒng)計完次數(shù),按升序排列即可。



代碼

C++

我的代碼

class Solution {public:    string originalDigits(string s) {        unordered_map m;        string nums[10] = {"zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine"};        string res;                for(char ch : s) m[ch]++;        // 0        if(m["z"] > 0)        {            for(int i=0 ; i 0)        {            int x = m["w"];            for(int i=0 ; i 0)        {            int x = m["u"];            for(int i=0 ; i 0)        {            int x = m["f"];            for(int i=0 ; i 0)        {            int x = m["x"];            for(int i=0 ; i 0)        {            int x = m["s"];            for(int i=0 ; i 0)        {            int x = m["g"];            for(int i=0 ; i 0)        {            int x = m["o"];            for(int i=0 ; i 0)        {            int x = m["t"];            for(int i=0 ; i 0)        {            int x = m["i"];            for(int i=0 ; i

C++

官方題解

class Solution {public:    string originalDigits(string s) {        unordered_map c;        for (char ch: s) {            ++c[ch];        }        vector cnt(10);        cnt[0] = c["z"];        cnt[2] = c["w"];        cnt[4] = c["u"];        cnt[6] = c["x"];        cnt[8] = c["g"];        cnt[3] = c["h"] - cnt[8];        cnt[5] = c["f"] - cnt[4];        cnt[7] = c["s"] - cnt[6];        cnt[1] = c["o"] - cnt[0] - cnt[2] - cnt[4];        cnt[9] = c["i"] - cnt[5] - cnt[6] - cnt[8];        string ans;        for (int i = 0; i < 10; ++i) {            for (int j = 0; j < cnt[i]; ++j) {                ans += char(i + "0");            }        }        return ans;    }};作者:LeetCode-Solution

Java

class Solution {    public String originalDigits(String s) {        Map<Character, Integer> c = new HashMap<Character, Integer>();        for (int i = 0; i < s.length(); ++i) {            char ch = s.charAt(i);            c.put(ch, c.getOrDefault(ch, 0) + 1);        }        int[] cnt = new int[10];        cnt[0] = c.getOrDefault("z", 0);        cnt[2] = c.getOrDefault("w", 0);        cnt[4] = c.getOrDefault("u", 0);        cnt[6] = c.getOrDefault("x", 0);        cnt[8] = c.getOrDefault("g", 0);        cnt[3] = c.getOrDefault("h", 0) - cnt[8];        cnt[5] = c.getOrDefault("f", 0) - cnt[4];        cnt[7] = c.getOrDefault("s", 0) - cnt[6];        cnt[1] = c.getOrDefault("o", 0) - cnt[0] - cnt[2] - cnt[4];        cnt[9] = c.getOrDefault("i", 0) - cnt[5] - cnt[6] - cnt[8];        StringBuffer ans = new StringBuffer();        for (int i = 0; i < 10; ++i) {            for (int j = 0; j < cnt[i]; ++j) {                ans.append((char) (i + "0"));            }        }        return ans.toString();    }}作者:LeetCode-Solution

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

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/125058.html

相關(guān)文章

  • LeetCode 423 英文重建數(shù)字[數(shù)組] HERODING的LeetCode之路

    摘要:解題思路首先要明確一點(diǎn),就是打亂的英文能夠還原成數(shù)字,然后觀察表格規(guī)律你就能發(fā)現(xiàn),有的數(shù)字一個字母就能決定出現(xiàn)。所以我們從單個字母就能知曉的數(shù)字出發(fā)進(jìn)行統(tǒng)計,用一個長度的數(shù)組來存儲字母個數(shù),然后對每一個數(shù)字一一統(tǒng)計,代碼如下 ...

    JerryZou 評論0 收藏0
  • leetcode423. Reconstruct Original Digits from Engl

    摘要:如對應(yīng)的英文表達(dá)為并繼續(xù)亂序成。要求輸入亂序的英文表達(dá)式,找出其中包含的所有的數(shù)字,并按照從小到大輸出。思路和代碼首先將數(shù)字和英文表示列出來粗略一看,我們知道有許多字母只在一個英文數(shù)字中出現(xiàn),比如只出現(xiàn)在中。 題目要求 Given a non-empty string containing an out-of-order English representation of digits...

    kviccn 評論0 收藏0
  • leetcode每日一題-559:N叉樹的最大深度

    摘要:每日一題叉樹的最大深度鏈接叉樹的最大深度題目分析簡單的搜索題目。只需要從根節(jié)點(diǎn)開始一下整個叉樹就可以得到答案了。主要是對要理解和掌握叉樹的遍歷。代碼作者作者 lee...

    caiyongji 評論0 收藏0
  • leetcode每日一題-859:親密字符串

    摘要:每日一題親密字符串鏈接親密字符串題目分析題目本身不是很難,但是有不少需要注意的地方,逐一來進(jìn)行分析。首先如果兩個字符串不一樣長,那么肯定是。 leetcode每日一...

    張遷 評論0 收藏0
  • leetcode每日一題-563:二叉樹的坡度

    摘要:每日一題二叉樹的坡度鏈接二叉樹的坡度題目分析簡單的問題。首先明確思路,我們需要遍歷每一個點(diǎn),然后求出該點(diǎn)左右子樹的值的總和,然后做差,答案累計這個差值即可。 lee...

    isLishude 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<