取任意四个字符,不过这四个字符有重复,求穷举出所有字符排列,应该怎么用C++实现?

取任意四个字符,不过这四个字符有重复,求穷举出所有字符排列,应该怎么用C++实现?比如给出字符序列2122求出所有排列组合,应该怎么办?求思路,我目前的思路就是把之前生成... 取任意四个字符,不过这四个字符有重复,求穷举出所有字符排列,应该怎么用C++实现?

比如给出字符序列 2122

求出所有排列组合,应该怎么办?求思路,我目前的思路就是把之前生成的每一个排列组合都存储在一个表中,生成新组合排列的时候先检查表中是否存在相同的排列组合,如果存在则忽略,可是这样空间效率太低,有没有更高效一点的办法?
展开
 我来答
Chhy2009
2011-11-19 · TA获得超过288个赞
知道小有建树答主
回答量:265
采纳率:0%
帮助的人:198万
展开全部
在排列前先计算一下字符的情况:共有4;3;2,2;2,1,1;1,1,1,1 情况。然后再处理,这样空间会省点。
gaojundz1
2011-11-19
知道答主
回答量:17
采纳率:0%
帮助的人:8.4万
展开全部
可以先统计字符个数
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式