2013面试题

给出a-z0-9,在其中选择三个字符组成一个密码,输出全部的情况,程序实现

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);
		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。
给定任意两个字符串,你是否能写出一个算法来计算它们的相似度呢?

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;
	}

	/**
	 * 获取两字符串的相似度
	 */
	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));
	}
}





2013 面试
您的回应...

相关话题

查看全部

也许你感兴趣

换一批

热门标签

更多