Java在长字符串中查找短字符串的实现多种方法

方案一:

补充:在输入短字符串时,如果有空格,可以在比较前用 trim()方法截取前后空白

 /*该方法只适用于有特殊分割符号的字符串*/
    System.out.println("请输入字符串:");
    Scanner str1=new Scanner(System.in);
    String s=str1.nextLine();
    System.out.println("请输入第二个字符串:");
    Scanner str2=new Scanner(System.in);
    String s2=str2.next();
    String[] i= s.split(" ");//对长字符串进行分割得到一个字符串数组
    int o=0;
    for (int j = 0; j <i.length ; j++) {
      if (s2.equals(i[j])==true){//对字符数组进行遍历比较
        o++;
      }
    }
    System.out.println("次数为:"+o);
  }

方案二:

 //如果替换未造成字符串长度损失,该方法则不适用
    System.out.println("请输入一个长字符串:");
    Scanner str1 = new Scanner(System.in);
    String s = str1.nextLine();
    System.out.println("请输入短字符串:");
    String s1 = str1.nextLine();
    String s3 = s.replaceAll(s1, "0");//字符替换
    int b1 = s.length() - s3.length();//计算出s字符串损失的长度
    int b2 = b1 / (s1.length() - 1);//根据规律计算出s1字符串在s字符串中出现的次数
    System.out.println("次数为:"+b2);

方案三:

  //该方法适用于各种模式
    System.out.println("请输入一个长字符串:");
    Scanner str1 = new Scanner(System.in);
    String s = str1.nextLine();
    System.out.println("请输入短字符串:");
    String s1 = str1.nextLine();
    int c=0;
    for (int i = 0; i <s.length()-s1.length() ; i++) {
      if (s1.equals(s.substring(i,i+s1.length()))){/*字符串比较,对长字符串进行截取,之后用截取得到的字符串与短字符串进行比较*/
        ++c;
      }
    }
    System.out.println("次数为: " + c);

到此这篇关于Java在长字符串中查找短字符串的实现多种方法的文章就介绍到这了,更多相关Java 查找字符串内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • java查找字符串中的包含子字符串的个数实现代码

    1. 用indexof的方法: public class Test11 { private static int counter = 0; /** * @param args */ public static void main(String[] args) { String str ="sdSS**&HGJhadHCASch& ^^"; int i = stringNumbers(str); System.out.println(i); } public static

  • java使用正则表达式查找包含的字符串示例

    本文实例讲述了java使用正则表达式查找包含的字符串.分享给大家供大家参考,具体如下: Hello.java: package hello; import java.util.regex.Matcher; import java.util.regex.Pattern; public class Hello { public static void main(String[] args) { String re = "\\[([^\\]]+)\\]"; String str = &quo

  • 基于java查找最长字符串代码实例

    题目:编写程序,针对输入的N个字符串,输出其中最长的字符串 输入样例: 4 zhaoming zhangming sunming liming 输出样例: 最长的字符串:zhangming 代码如下 import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int t = sc.nextInt(); int

  • java eclipse 整个项目或包查找只定字符串并替换操作

    java eclipse经常会用到整个类进行查找,ctrl+f,然后replaceall(XX,toXX).但是最近要对webservice上的项目进行检查,里面的运行程序不能有system.out.println这样的语句,因为服务器上的控制台输出会存储到一个指定路径的文件里,超过9gtomcat就会运行变慢,甚至挂掉.所以这里要用,ctrl+h,开启全项目或者全包搜索,用法如下: 1.选中项目名称或者包名称位置,ctrl+h 2弹出的界面中选取,file Search,在其中输入要查找的字符

  • Java实现查找当前字符串最大回文串代码分享

    先看代码 public class MaxHuiWen { public static void main(String[] args) { // TODO Auto-generated method stub String s = "abb"; MaxHuiWen(s); } //1.输出回文串 public static void MaxHuiWen(String s){ //存储字符串的长度 int length = s.length(); //存储最长的回文串 String M

  • java 查找字符串所在的位置代码

    使用了 String 类的 indexOf() 方法在字符串中查找子字符串出现的位置,如过存在返回字符串出现的位置(第一位为0),如果不存在返回 -1.方便判断和截取字符串! 语法:stringObject.indexOf(searchvalue,fromindex) 参数 描述 searchvalue 必需.规定需检索的字符串值. fromindex 可选的整数参数.规定在字符串中开始检索的位置.它的合法取值是0到 - 1.如省略该参数, 则将从字符串的首字符开始检索. 该方法将从头到尾地检索

  • Java字符串查找的三种方式

    indexof方法: 注解:indexOf 方法返回一个整数值,指出 String 对象内子字符串的开始位置.如果没有找到子字符串,则返回-1. public class IndexOf{ public static void main(String[] args){ String s="李宏#王海#林巧#陆寻#唐梅"; String q="#"; //需要查找的字符串 String err="*"; //不存在的字符串 int i=0; for

  • java字符串常用操作方法(查找、截取、分割)

    如下所示: public class 字符串常用操作 { public static void main(String[] args) { /* * 查找子串 */ String str1="dwqae12232aebdalf"; //查找指定字符第一次出现的位置 int first1=str1.indexOf(97);//参数为字符的ascii码 //查找指定字符串第一次出现的位置 int first2=str1.indexOf("12"); //查找指定字符第一

  • 基于java查找并打印输出字符串中字符出现次数

    今天在面试时遇到一道算法的题: 给定一个字符串,输出每次字符出现的次数:要求按照顺序输出: 自己的思路开始是: 1.把String转换char数组 2.直接去遍历数组,获取每个字符出现次数,遇到不同时候重新记录 3.把结果用StringBuffer拼接后输出 public class Record { public static void main(String[] args) { System.out.println("直接遍历数组的方法:"+compressStrArray(&qu

  • Java的字符串中对子字符串的查找方法总结

    Java中字符串中子串的查找共有四种方法,如下: 1.int indexOf(String str) :返回第一次出现的指定子字符串在此字符串中的索引. 2.int indexOf(String str, int startIndex):从指定的索引处开始,返回第一次出现的指定子字符串在此字符串中的索引. 3.int lastIndexOf(String str) :返回在此字符串中最右边出现的指定子字符串的索引. 4.int lastIndexOf(String str, int startI

随机推荐