|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
C++编译的是本地码,优点是启动快,而且可以精确控制资源因此可以开发很高效的程序.缺点是编程麻烦,而且容易留下安全隐患.跨平台靠源代码在各个平台间分别编译(一处编写到处编译)
最年夜字串成绩形貌也许就是给定2个字符串,找出他们两个共有的最长字符串。好比一个是"tabcfg"别的一个"abckj"那末最年夜子串就是"abc".
静态计划算法最主要的就是分化成绩,找出递回。说一下我的思索思绪,起首拿到2个字符串,怎样找到最宗子串呢?
1.假定他们(字符串a,b)的头字母不不异的话,那末分离往失落首字母对照,也就是说用a.subString(1)和b对照,用b.subString(1)和a对照,最宗子字符串没变吧?谜底是一定的。ok递回呈现了,停止前提就是有一个字符串变空,前往值就是a和b的最宗子串。
b.假定他们头字母不异,那末一向对照下往,晓得二者的第n个字母不不异,然后把前n-1个字母存为子字符串c,把a.subString(1)和b前往了局记为d,b.subString(1)和a前往了局记为e,那末前往c,d和e最长的一个(感激lexy的批评,之前的确漏掉一种情形。不该该间接把后面的不异的往失落间接对照的,如今代码已更新了)。
大概有人说应当从前面往后面对照,找到不异的然后一个个再往前比,实在事理都是一样的,关头要找到分化成绩的办法。这里只是举一反三,上面是详细的java完成。
import java.util.HashMap;
import java.util.Map;
/**
* @author HEACK
*
*/
public class CompareStr {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
String str1 = "abcde1234567abcdefghijk";
String str2 = "abcdefgh12345";
//String str2 = "abc happyies dutcbirthday peter";
CompareStr cj = new CompareStr();
System.out.println(cj.getLongestString(str1,str2));
}
private boolean isEmpty(String str) {
return str == null || str.trim().length() == 0;
}
private Map map = new HashMap();
private String getLongestString(String str1, String str2) {
if (isEmpty(str1) || isEmpty(str2)) {
return "";
}
StringBuffer key = new StringBuffer();
key.append(str1).append("&&").append(str2);
if (map.containsKey(key.toString())) {
return (String)map.get(key.toString());
}
StringBuffer longestStr = new StringBuffer();
char[] str1List = str1.toCharArray();
char[] str2List = str2.toCharArray();
int i = 0;
for (i = 0; i < str1List.length && i < str2List.length; i++) {
if (str1List[i] == str2List[i]) {
longestStr.append(str1List[i]);
} else {
break;
}
}
String subStr1 = str1.substring(i);
String subStr2 = str2.substring(i);
if (i == 0) {
String retStr1 = getLongestString(subStr1.substring(1), subStr2);
String retStr2 = getLongestString(subStr1, subStr2.substring(1));
String returnStr = retStr1.length() >= retStr2.length() ? retStr1 : retStr2;
map.put(key.toString(), returnStr);
return returnStr;
} else {
String retStr1 = getLongestString(str1.substring(1), str2);
String retStr2 = getLongestString(str1, str2.substring(1));
String retStr = retStr1.length() > retStr2.length() ? retStr1
: retStr2;
String returnStr = retStr.length() >= longestStr.toString().length() ? retStr
: longestStr.toString();
map.put(key.toString(), returnStr);
return returnStr;
}
}
}
HashMap用来存储已盘算过的字符串,用空间换工夫。代码固然还能够优化,您也能够一试技艺哦。
最后我再次声明,我并没有说不看好java,实际上我对java很乐观的,毕竟她正在不断改进中,我相信她总有一天会和.net网页编程并驾齐驱的 |
|