public static void main(String[] args) {
// TODO Auto-generated method stub
String[] str = new String[200];
String str1 = "0100110001010001";
int count = 0; //用来计算不同不同字符串的个数
int temp = 0;
for(int i = 0;i < str1.length() - 1;i++) {
for(int j = i+1;j < str1.length();j++) {
for(int k = temp;k < str.length;k++) {
if(str1.substring(i, j).equals(str[k])) {
break;
}else {
str[k] = str1.substring(i, j);
count++;
temp++;
break;
}
}
}
}
System.out.println(count);
}
中间哪里出错了呢?看了好长时间没有发现。
这段代码的错误在于,程序在计算不同字符串的个数时,使用的方法不够严谨。
在for循环中使用了两个索引变量i和j,它们会导致程序重复计算一些字符串。
变量temp未使用。
在循环中使用了break语句,当某个字符串在str数组中找到相同值时,程序会终止循环,但这样会导致程序错误地计算不同字符串的个数。
所以这段代码需要修改才能正确地计算不同字符串的个数。