V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
Wonderwall
V2EX  ›  JavaScript

选出单词中有重复的字母数量最多的一个

  •  
  •   Wonderwall · 2015-07-20 12:59:14 +08:00 · 3723 次点击
    这是一个创建于 3462 天前的主题,其中的信息可能已经有所发展或是发生改变。
    输入是array,如[“apple”, “banana”, “cranberry”]

    选出单词中有重复的字母数量最多的一个(如果有一样重复数量的,选第一个),比如刚才例子这一组,选出的是”banana"(3个a,虽然cranberry也有3个r,但是banana在前,所以选banana)。如果没有单词有重复字母,比如[“a”, “b”],返回”-1"。

    我下面写的代码,一般都对,但是一但这个有重复的字母数量最多的单词在最后一位,结果就不对(最后的单词似乎没被鉴定),比如[“a”, “bb”, “ccc”],应返回cc,但我的会返回”bb”.




    我知道我写的这个不是最有效率的,但是想知道问题出在哪里,请指教,谢谢!
    7 条回复    2015-07-21 07:20:39 +08:00
    Wonderwall
        1
    Wonderwall  
    OP
       2015-07-20 13:18:10 +08:00
    更正:输入是string,所以第一步我先把它变了array。感谢!
    hyesun
        2
    hyesun  
       2015-07-20 16:44:43 +08:00   ❤️ 1
    楼主你这个代码。。我输入 "a bb ccc" 输出来的是 -1。你把 return word 放在第一层循环里,循环一次就返回了,后面的字符串怎么能被处理。。
    anerevol
        3
    anerevol  
       2015-07-20 17:02:38 +08:00   ❤️ 1
    @hyesun 哈哈 果然是 看了半天没看出啥问题 原来是这样
    imlonghao
        4
    imlonghao  
       2015-07-20 23:47:40 +08:00   ❤️ 1
    学着写了个 Python 版本
    我感觉我还是不会用 Python3 , return 那里感觉我是傻逼。。。。。。

    https://gist.github.com/imlonghao/df181988bd285753c1b8
    Wonderwall
        5
    Wonderwall  
    OP
       2015-07-21 00:22:20 +08:00
    @hyesun 啊!我去!原来如此!
    @anerevol @imlonghao 谢谢两位!
    madeinclojure
        6
    madeinclojure  
       2015-07-21 07:15:56 +08:00
    ```clojure

    (defn freq-of-cha
    [str]
    (->> str
    frequencies
    (sort-by val >)
    first
    second
    (vector str)))

    (defn answer
    [col]
    (->> col
    (map freq-of-cha)
    (sort-by second >)
    ffirst))

    ```
    madeinclojure
        7
    madeinclojure  
       2015-07-21 07:20:39 +08:00
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5479 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 06:57 · PVG 14:57 · LAX 22:57 · JFK 01:57
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.