临睡前向 v 友请教一个问题, js 如何实现字符串‘a’到‘zzzz’的遍历? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
xiaoxiuaoliang
V2EX    问与答

临睡前向 v 友请教一个问题, js 如何实现字符串‘a’到‘zzzz’的遍历?

  •  
  •   xiaoxiuaoliang 2017-02-26 00:47:57 +08:00 4011 次点击
    这是一个创建于 3197 天前的主题,其中的信息可能已经有所发展或是发生改变。
    如题中所述,使用 Javascript ,如何实现从‘ a ’到‘ zzzz ’的遍历,即:
    a
    b
    ...
    z
    aa
    ab
    ...
    az
    ba
    bb
    ...
    ...
    zz
    aaa
    aab
    ...
    ...
    zzz
    aaaa
    aaab
    ...
    zzzz

    如果此题可以表述为:如何实现长度为 1 的字符串‘ a ’到长度为 4 的字符串‘ zzzz ’的遍历,那么更一般地,如何实现长度为 m 的字符串 a 到长度为 n 的字符串 b 的遍历?
    第 1 条附言    2017-02-26 22:36:40 +08:00
    十分感谢 v 友们,回答很给力~

    哈哈哈 此题完结!
    第 2 条附言    2017-03-02 16:57:26 +08:00

    今天有空写了一下,放在了这里: http://codepen.io/yummy/pen/aJdPRq?editors=0011

    实现了任意两个小写英文字符之间所有字符的遍历。 方法比较笨拙,但好在满足了自己的需求。

    23 条回复    2017-02-26 22:58:46 +08:00
    azh7138m
        1
    azh7138m  
       2017-02-26 00:51:25 +08:00 via Android
    这个和从 x 遍历到 y 并输出是一样的,只不过这个是 26 进制罢了
    aheadlead
        2
    aheadlead  
       2017-02-26 00:53:56 +08:00 via iPhone
    写个 dfs … 先睡了
    starvedcat
        3
    starvedcat  
       2017-02-26 03:46:45 +08:00   1
    这题很基础,高手应该不太会愿意动手写。本人献丑了

    MIN_LENGTH = 2;
    MAX_LENGTH = 3;

    for (var len = MIN_LENGTH; len <= MAX_LENGTH; len++) {
    var word_array = [];
    for (var j = 0; j < len; j++) {
    word_array[j] = 0
    }

    while (true) {
    var word = '';
    for (var k = 0; k < len; k++) {
    word += String.fromCharCode(97 + word_array[k]);
    }
    console.log(word);

    for (k = len - 1; k >= 0; k--) {
    if (word_array[k] < 25) {
    break;
    }
    }

    if (k == -1) {
    break;
    }

    word_array[k]++;
    for (k++; k < len; k++) {
    word_array[k] = 0;
    }
    }
    }
    des
        4
    des  
       2017-02-26 06:57:20 +08:00 via Android
    @starvedcat 换我应该会按照一楼说的方式,预先计算 m 到 n 有多少个及总共有多少个,从最小合适的数(如果最少为一位,从零开始)
    然后通过类似进制转换的方式进行映射
    aheadlead
        5
    aheadlead  
       2017-02-26 07:04:06 +08:00
    刚醒
    抱歉不是很会写 js
    用 python 代替吧

    def rich(length):
    ....alphabet = [chr(_) for _ in range(ord('a'), ord('z')+1)]
    ....fu = [[], alphabet]
    ....for i in range(1, length):
    ........fu.append([c + s for c in alphabet for s in fu[1]])
    ....return fu
    vibbow
        6
    vibbow  
       2017-02-26 07:07:39 +08:00
    @aheadlead python 的缩进......
    cyr1l
        7
    cyr1l  
       2017-02-26 07:59:51 +08:00 via iPhone
    @aheadlead V2EX 回复不能缩进,看把 python 程序员逼得。
    aheadlead
        8
    aheadlead  
       2017-02-26 08:03:00 +08:00
    @vibbow @cyr1l 蛤哈原谅我比较懒不想打开 gist
    aheadlead
        9
    aheadlead  
       2017-02-26 08:05:59 +08:00   1
    不过上面好像写错了一个地方,不是很懂为什么刚打错了……

    def rich(length):
    ....alphabet = [chr(_) for _ in range(ord('a'), ord('z')+1)]
    ....fu = [[], alphabet]
    ....for i in range(1, length):
    ........fu.append([c + s for c in alphabet for s in fu[i]]) # 在这里
    ....return fu
    hd7771
        10
    hd7771  
       2017-02-26 08:49:24 +08:00 via Android
    你这玩意就是 26 进制的数,直接把 10 进制转换成 26 就行了。
    wyfyw
        11
    wyfyw  
       2017-02-26 08:54:08 +08:00
    @hd7771 不一样,你想想每次都是从 aa 、 aaaa 开始的, 26 进制数显然不是。
    kindjeff
        12
    kindjeff  
       2017-02-26 09:08:14 +08:00 via iPhone
    @wyfyw 意思是你自己再手写一个进制转换就可以了。
    wyfyw
        13
    wyfyw  
       2017-02-26 09:15:47 +08:00
    @kindjeff 我的意思是如果只要特定长度的,如长度为 4 , aaaa 可以看作 0000 ,所以是 25 进制。
    wyfyw
        14
    wyfyw  
       2017-02-26 09:17:30 +08:00
    @kindjeff 我错了。。。就是二十六精致
    zhy0216
        15
    zhy0216  
       2017-02-26 09:52:10 +08:00
    def hah(length):
    ....if length == 0: return [[""]]
    ....return hah(length-1) + [[c+chr(97+i) for c in (hah(length-1)[-1]) for i in range(26)]]
    hxsf
        16
    hxsf  
       2017-02-26 09:57:35 +08:00   2
    zhy0216
        17
    zhy0216  
       2017-02-26 09:58:05 +08:00
    忘记加个变量 cache 一下...
    def hah(length):
    ....if length == 0: return [[""]]
    ....cached = hah(length-1)
    ....return cached + [[c+chr(97+i) for c in (cached[-1]) for i in range(26)]]
    7sDream
        18
    7sDream  
       2017-02-26 13:09:56 +08:00
    xiaoxiuaoliang
        19
    xiaoxiuaoliang  
    OP
       2017-02-26 22:16:39 +08:00
    @starvedcat 赞~ 将代码适当封装成函数就更棒了,类似 @hxsf 那样
    xiaoxiuaoliang
        20
    xiaoxiuaoliang  
    OP
       2017-02-26 22:18:32 +08:00
    @aheadlead python 基本不了解 哈哈 不过还是非常感谢你的回复,铜币已送上~
    xiaoxiuaoliang
        21
    xiaoxiuaoliang  
    OP
       2017-02-26 22:22:36 +08:00
    @zhy0216 厉害了我的司机,精简的代码总是看起来非常酷炫
    xiaoxiuaoliang
        22
    xiaoxiuaoliang  
    OP
       2017-02-26 22:30:04 +08:00
    @hxsf 铜币已奉上,非常感谢你的回复,出去浪了一天,这次完完全全的来了次"拿来主义" 嘎嘎
    hxsf
        23
    hxsf  
       2017-02-26 22:58:46 +08:00
    @xiaoxiuaoliang #22 用了 ES6 语法,用之前确定能用,或者改成 es5 语法
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5287 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 34ms UTC 06:49 PVG 14:49 LAX 22:49 JFK 01:49
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86