CSP201409-3(字符串匹配)(Java 100分)

版权声明:本文为博主原创文章,转载请注明出处 https://blog.csdn.net/qq_24681499/article/details/79962978

问题描述
  给出一个字符串和多行文字,在这些文字中找到字符串出现的那些行。你的程序还需支持大小写敏感选项:当选项打开时,表示同一个字母的大写和小写看作不同的字符;当选项关闭时,表示同一个字母的大写和小写看作相同的字符。
输入格式
  输入的第一行包含一个字符串S,由大小写英文字母组成。
  第二行包含一个数字,表示大小写敏感的选项,当数字为0时表示大小写不敏感,当数字为1时表示大小写敏感。
  第三行包含一个整数n,表示给出的文字的行数。
  接下来n行,每行包含一个字符串,字符串由大小写英文字母组成,不含空格和其他字符。
输出格式
  输出多行,每行包含一个字符串,按出现的顺序依次给出那些包含了字符串S的行。
样例输入
Hello
1
5
HelloWorld
HiHiHelloHiHi
GrepIsAGreatTool
HELLO
HELLOisNOTHello
样例输出
HelloWorld
HiHiHelloHiHi
HELLOisNOTHello
样例说明
  在上面的样例中,第四个字符串虽然也是Hello,但是大小写不正确。如果将输入的第二行改为0,则第四个字符串应该输出。
评测用例规模与约定
  1<=n<=100,每个字符串的长度不超过100。
CSP最水的水题吧,难度比第二题还简单。
Java代码如下:

package csp201409;
import java.util.Scanner;
public class MapString {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner sc = new Scanner(System.in);
        String s=sc.next();
        int opt=sc.nextInt();
        int m=sc.nextInt();
        for(int i=0;i<m;i++) {
            String st=sc.next();
            if(opt==1) {
                if(st.contains(s)) {
                    System.out.println(st);
                }
            }
            else {
                if(st.toUpperCase().contains(s.toUpperCase())){
                    System.out.println(st);
                }
            }
        }
    }

}
阅读更多
想对作者说点什么?

博主推荐

换一批

没有更多推荐了,返回首页