我希望将123、132、213、231、312、321全排列输出为1,2,3,请大侠给出算法或者java代码,

问题描述:

我希望将123、132、213、231、312、321全排列输出为1,2,3,请大侠给出算法或者java代码,
如果有排列是123、124、134、213.432共24个,即P43,能够输出1,2,3,4
换种说法,我从m个数字里面选n个数字按照一定的顺序排列起来,数学叫Pmn,上下标打不起,如果m=n,就叫全排列.例如m=n=3,其排列为:123、132、213、231、312、321共6组,P33=3*2*1=6;如果m=4,n=3,起排列为:123、124、132、134..431、432共24组,P43=4*3*2=24;现在我希望的是如果我已知一堆排列,能找出是哪些数字组合在一起才能得到这些排列.例如:已知排列有123、132、213、231、312、321,需要输出1、2、3,但如果我有123、132、213、231、312、412,则没有任何输出;再如有排列123、124、132、134..431、432共24组,需要输出1、2、3、4,不知现在是否说清楚了

遍历所有排列的数据:例 123将之拆分的 ‘1’ ‘2’ ‘3‘ 用一数组存取存在的数,虽然这办法效率不高,但能你实现你的所要的效果,你按这个思想写一下吧.实在不行,我再帮你写一个不是很明白你的思路,你要能写,最好不过!这几天有事,我写了一个,你参考一下吧:public class Sample{public static void main(String[] args){String[] data = {"123","12","234"}; //你的排列数据char []c = new char[32]; //存放将String转换为char数组char ret[] = new char[32];//存放结果int i,dlength,a,j,z,flag;a = 0;for(i = 0; i