首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > J2SE开发 >

那位大神帮小弟我看看这题,要判断字符在字符串中出现的次数

2012-09-10 
那位大神帮我看看这题,要判断字符在字符串中出现的次数!import java.util.Scannerpublic class Counter{p

那位大神帮我看看这题,要判断字符在字符串中出现的次数!
import java.util.Scanner;

public class Counter
{
public int counter(String inputs, String word)
{
int counter = 0;
int index = 0;
for (int i = 0; i < inputs.length() - 1; i++)
{
if (inputs.indexOf(word) == 0)
{
counter++;
index++;
}
}
return counter;
}

public static void main(String[] args)
{
Scanner input = new Scanner(System.in);
Counter find = new Counter();
System.out.print("请输入一个字符串:");
String inputs = input.next();
System.out.print("请输入要查找的字符:");
String word = input.next();
int num = find.counter(inputs, word);
System.out.println(inputs + "中包含" + num + "个" + word);
}
}
我输出的结果是字符的下标,而不是次数,那位大神帮我修改一下~谢谢!

[解决办法]

Java code
import java.util.Scanner;public class Counter {    public int counter(String inputs, String word) {        int counter = 0;        int index =0;        for (int i = 0; i <= inputs.length() - 1; i++) {            if ( ( index = inputs.indexOf(word) ) !=-1 ) {                counter++;                inputs = inputs.substring(index+word.length());            }        }        return counter;    }    public static void main(String[] args) {        Scanner input = new Scanner(System.in);        Counter find = new Counter();        System.out.print("请输入一个字符串:");        String inputs = input.next();        System.out.print("请输入要查找的字符:");        String word = input.next();        int num = find.counter(inputs, word);        System.out.println(inputs + "中包含" + num + "个" + word);    }}
[解决办法]
Java code
import java.util.Scanner;public class Counter {    public int counter(String inputs, String word) {        int counter = 0;        int index =0;//        //        for (int i = 0; i < inputs.length() - 1; i++) { //要用 <=//            if (inputs.indexOf(word) == 0) {  //要换成!=-1  !=-1意为找到一次,让count++才有意义//                counter++;//                index++;  //仔细看看你的index,哪都没用到,这是毛用...//            }//        }//        return counter;                for (int i = 0; i <= inputs.length() - 1; i++) {            if ( ( index = inputs.indexOf(word) ) !=-1 ) {                                //上句代码意思为若inputs="abcdefgabckabcii"                //                          word="abc";                //则每找到一次abc就,让inputs=从c后的那个d开始形成的子串即为defgabckabcii;                //然后再循环往覆,直到结束.                                //而上面的for(循环其实意思不大),最好直接用//            while(( index = inputs.indexOf(word) ) !=-1 ){//                counter++;//                inputs = inputs.substring(index+word.length());//            }                            }        }        return counter;    }    public static void main(String[] args) {        Scanner input = new Scanner(System.in);        Counter find = new Counter();        System.out.print("请输入一个字符串:");        String inputs = input.next();        System.out.print("请输入要查找的字符:");        String word = input.next();        int num = find.counter(inputs, word);        System.out.println(inputs + "中包含" + num + "个" + word);    }}
[解决办法]
Java code
String str = "aafcfasfqefdsasfaff";                  //e表示需要匹配的数据,使用Pattern建立匹配模式          Pattern p = Pattern.compile("as");                  //使用Matcher进行各种查找替换操作          Matcher m = p.matcher(str);          int i = 0;          while(m.find()){              i++;          }                    System.out.println(i);
------解决方案--------------------


假定字符串是: str
要查找的是: word

可以:
String tmp = str.replaceAll("\\Q" + word + "\\E", ""); // 将匹配的字符串全部干掉
int num = (str.length() - tmp.length()) / word.length(); // 这就是统计出的字符串出现次数了。

局限性:
如果word里面有一些特殊转义组合的话,就会失效。

热点排行
Bad Request.