[洛谷P1308] 统计单词数(Java)

传送门:P1308 统计单词数

想熟悉一下 Java,所以来写写水题。题意是,给定一段文本与一个单词,要求找出该单词在文本中第一次出现的位置以及出现的次数,不区分大小写,但必须单词级的完全相同。因为要求单词完全匹配,又单词前后都具有一个空格,所以可以将单词与文本的两端都加上空格字符。这样,就可以直接用系统实现的字符串查找了而且不需要对第一次出现的位置进行修正。

import java.util.Scanner;

public class P1308 { // 提交Java代码要求类名为Main
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String word = ' ' + scanner.nextLine().toLowerCase() + ' ';
        String text = ' ' + scanner.nextLine().toLowerCase() + ' ';

        int firPos = text.indexOf(word); // 相当于C++的find
        if (firPos != -1) {
            int tmp = firPos, cnt = 0;
            while (tmp != -1) {
                tmp = text.indexOf(word, tmp+1);
                cnt++;
            }
            System.out.println(cnt + " " + firPos); // " "不可写成' ',否则会转为int
        } else {
            System.out.println(-1);
        }
    }
}

猜你喜欢

转载自blog.csdn.net/HNUCSEE_LJK/article/details/104128379