douyonglang4845 2017-02-22 23:11
浏览 105
已采纳

如何在Golang中列出组合可能性

Any idea to make the best code for combination :

with this :

letters := []string{"a", "b", "c", "d"}

to have : a ab ac ad abc abd b bc bcd etc ...

regards and thanks

  • 写回答

1条回答 默认 最新

  • dstew32424 2017-02-23 02:35
    关注

    You are looking for Powerset:

    One approach is:

    Start with a slice with one empty element, let's call it result:

    [[]]

    Keep the previous slice, and create a new slice with first element a of you data structure added to you to every element in you original slice.

    [[]] <--old; [[a]] <--new

    merge them

    [[], [a]]

    Do the same thing for second element b:

    [[], [a]] <--old; [[b], [ab]] <--new

    => [[], [a], [b], [ab]]

    for c:

    [[], [a], [b], [ab]] <--old; [[c], [ac], [bc], [abc]] <--new

    => [[], [a], [b], [ab], [c], [ac], [bc], [abc]]

    and so on..

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 目详情-五一模拟赛详情页
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b