原题链接:字符排列问题
解题思路:全排列算法列出所有的可能,然后去检查无重复项有几个
注意事项:
参考代码:
public class 字符串排列 {
public static String [] str = new String [3628800];
public static int len = 0;
/**
* 全排列算法
* @param chars
* @param from
* @param to
*/
public static void pl(char[] chars,int from,int to) {
if(from == to) {
str[len++] = new String(chars);
return;
}
for(int i=from;i<to+1;i++) {
swap(chars, from, i);
pl(chars, from+1, to);
swap(chars, i, from);
}
}
/**
* 交换
* @param chars
* @param i
* @param j
*/
public static void swap(char[] chars,int i,int j) {
char temp;
temp = chars[i];
chars[i] = chars[j];
chars[j] = temp;
}
/**
* 算阶乘
* @param num
* @return
*/
public static long jc(int num) {
long jc = 1;
for(int i=1;i<num+1;i++) {
jc=jc*i;
}
return jc;
}
/**
* 检验数组里不重复的元素
* @param args
*/
public static int countBcf(String[] str) {
String [] cf = new String [3628800];
int j=0;
cf[j++] = str[0];
for(int i=1;str[i]!=null;i++) {
int k;
for(k=0;k<j;k++) {
if(str[i].equals(cf[k])) {
break;
}
}
if(k==j) {
cf[j++] = str[i];
}
}
return j;
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner in = new Scanner(System.in);
int n = in.nextInt();
String zf = in.next();
pl(zf.toCharArray(), 0, zf.length()-1);
System.out.println(countBcf(str));
}
}0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复