给出a-z0-9,在其中选择三个字符组成一个密码,输出全部的情况,程序实现
[java]
import java.util.ArrayList;
import java.util.List;
public class Demo {
static char[] buf = { '1', '2', '3' , '4'};
static List<String> list = new ArrayList<String>();
public static void main(String[] args) {
select(buf, list, 3); www.zzzyk.com
for (String str : list){
System.out.println( str ) ;
}
System.out.println("In total: " + list.size() );
}
public static void select(char[] source, List<String> arrayList, int num) {
int l = source.length ;
char[] temp = new char[num];
System.arraycopy(source, 0, temp, 0, num);
arrayList.add(new String(temp));
for (int i = num; i < l; i++) {
for (int j = 0; j < num; j++){
char tempChar = temp[j];
temp[j] = source[i];
arrayList.add(new String(temp));
temp[j] = tempChar;
}
}
}
}
2、许多程序会大量使用字符串。对于不同的字符串,我们希望能够有办法判断其相似程序。我们定义一套操作方法来把两个不相同的字符串变得相同,具体的操作方法为:
1.修改一个字符(如把“a”替换为“b”);
2.增加一个字符(如把“abdd”变为“aebdd”);
3.删除一个字符(如把“travelling”变为“traveling”);
比如,对于“abcdefg”和“abcdef”两个字符串来说,我们认为可以通过增加/减少一个“g”的方式来达到目的。上面的两种方案,都仅需要一 次 。把这个操作所需要的次数定义为两个字符串的距离,而相似度等于“距离+1”的倒数。也就是说,“abcdefg”和“abcdef”的距离为1,相似度 为1/2=0.5。
给定任意两个字符串,你是否能写出一个算法来计算它们的相似度呢?
[java]
public class Levenshtein {
public int ld(String str1, String str2) {
// Distance
int[][] d;
int n = str1.length();
int m = str2.length();
int i; // iterate str1
int j; // iterate str2
char ch1; // str1
char ch2; // str2
int temp;
if (n == 0) {
return m;
}
if (m == 0) {
return n;
}
d = new int[n + 1][m + 1];
for (i = 0; i <= n; i++) {
d[i][0] = i;
}
for (j = 0; j <= m; j++) {
d[0][j] = j;
}
for (i = 1; i <= n; i++) {
ch1 = str1.charAt(i - 1);
// match str2
for (j = 1; j <= m; j++) {
ch2 = str2.charAt(j - 1);
if (ch1 == ch2) {
temp = 0;
} else {
temp = 1;
}
d[i][j] = min(d[i - 1][j] + 1, d[i][j - 1] + 1, d[i - 1][j - 1]
+ temp);
}
}
return d[n][m];
}
/**
* 取最小的数
* */
private int min(int one, int two, int three) {
return (one = one < two ? one : two) < three ? one : three;
} www.zzzyk.com
/**
* 获取两字符串的相似度
*/
public float getSimilarityRatio(String str, String target) {
return (1/((float)ld(str, target)+1));
}
public static void main(String[] args) {
Levenshtein lt = new Levenshtein();
String str = "huang" ;
String target = "huang" ;
System.out.println(lt.getSimilarityRatio(str, target));
}
}