当前位置:编程学习 > JAVA >>

其中选择三个字符组成一个密码

给出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));  
    }  
}  
 
 
 
补充:软件开发 , Java ,
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,