Java 字符串包含_实现字符串的复制

Java 字符串包含_实现字符串的复制1问题描述给定一长字符串A和一短字符串B。请问,如何最快地判断出短字符串B中的所有字符是否都在长字符串A中?请编写一个判断函数实现此功能。为简单起见,假设输入的字符串只包含小写英文字母。下面举几个例子。(1)如果字符串A是”abcd”,字符串B是”bad”,答案是包含,因为字符串B中的字母都在字符串A中,或者说B是A的真子集。(2)如果字符串A是”abcd”,字符串B是”bce”,答案是…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

1 问题描述
给定一长字符串A和一短字符串B。请问,如何最快地判断出短字符串B中的所有字符是否都在长字符串A中?请编写一个判断函数实现此功能。

为简单起见,假设输入的字符串只包含小写英文字母。下面举几个例子。

(1)如果字符串A是”abcd”,字符串B是”bad”,答案是包含,因为字符串B中的字母都在字符串A中,或者说B是A的真子集。

(2)如果字符串A是”abcd”,字符串B是”bce”,答案是不包含,因为字符串B中的字母e不在字符串A中。

(3)如果字符串A是”abcd”,字符串B是”aab”,答案是包含,因为字符串B中的字母a包含在字符串A中。

2 解决方案
2.1 蛮力轮询法

判断字符串B中的字符是否都在长字符串A中,最直观的思路则是:轮询B中每一个字符,逐个与A中每个字符进行比较,看是否都在字符串A中。

具体代码如下:

package com.liuzhen.string_1;

public class StringContain {
    //方法1:蛮力轮询
    /*
     * 参数A:给定的长字符串A
     * 参数B:给定的短字符串B
     * 函数功能:如果B中所有字符在A中均出现过,则返回true,否则返回false
     */
    public boolean bruteContain(String A,String B){
        boolean result = false;
        char[] arrayA = A.toCharArray();
        char[] arrayB = B.toCharArray();
        int testLen = 0;            //用于计算B中与A匹配字符个数
        for(int i = 0;i < arrayB.length;i++){
            for(int j = 0;j < arrayA.length;j++){
                if(arrayB[i] == arrayA[j]){
                    testLen++;
                    break;
                }
            }
        }
        if(testLen == arrayB.length)        //当B个所有字符均和A中字符匹配时
            result = true;
        return result;
    }
    
    
    public static void main(String[] args){
        StringContain test = new StringContain();
        String A = "abcd";
        String B = "aab";
        if(test.bruteContain(A, B))
            System.out.println("使用蛮力轮询法得到结果:A字符串包含B字符串");
        else
            System.out.println("使用蛮力轮询法得到结果:A字符串不包含B字符串");
    }
}

运行结果:

使用蛮力轮询法得到结果:A字符串包含B字符串

2.2 素数相乘法
思路如下:

(1)按照从小到大的顺序,用26个素数分别代替长字符串A中的所有字母。

(2)遍历字符串A,求得A中所有字母对于的素数的乘积。

(3)遍历短字符串B,判断上一步得到的乘积能否被B中的字母对于的素数整除。

(4)输出结果。

package com.liuzhen.string_1;

public class StringContain {
    
    //方法2:素数相乘
    /*
     * 参数A:给定的长字符串A
     * 参数B:给定的短字符串B
     * 函数功能:如果B中所有单个字符对应素数能被A中所有字符对应素数之积整除,则返回true,否则返回false
     */
    public boolean primeContain(String A,String B){
        boolean result = true;
        int[] primes = {2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101};
        long mulSum = 1;
        char[] arrayA = A.toCharArray();
        char[] arrayB = B.toCharArray();
        for(int i = 0;i < arrayA.length;i++)
            mulSum *= primes[arrayA[i] - 'a'];
        for(int j = 0;j < arrayB.length;j++){
            int temp = (int) (mulSum % primes[arrayB[j] - 'a']);
            if(temp != 0){               //此时,A中不包含arrayB[j]字符
                result = false;
                return result;
            }
        }
        return result;
    }
    
    
    public static void main(String[] args){
        StringContain test = new StringContain();
        String A = "abcd";
        String B = "aab";
        if(test.placeContain(A, B))
            System.out.println("使用素数相乘法得到结果:A字符串包含B字符串");
        else
            System.out.println("使用素数相乘法得到结果:A字符串不包含B字符串");
    }
}

运行结果:

使用素数相乘法得到结果:A字符串包含B字符串

2.3 位运算法

用位运算(26位整数表示)为长字符串A计算出一个“签名”(利用位或运算),再逐一将短字符串B中的字符放到A中进行查找(PS:利用位与运算)。

package com.liuzhen.string_1;

public class StringContain {
    
    //方法3:位运算法
    /*
     * 参数A:给定的长字符串A
     * 参数B:给定的短字符串B
     * 函数功能:如果B中每个字符进行处理后的对应二进制值与A中所有字符进行处理对应二进制值的求或运算
     * ,在单独进行求与运算,一旦出现0,则返回false,否则返回true
     */
    public boolean placeContain(String A,String B){
        boolean result = true;
        char[] arrayA = A.toCharArray();
        char[] arrayB = B.toCharArray();
        int hash = 0;
        for(int i = 0;i < arrayA.length;i++)
            hash |= (1 << (arrayA[i] - 'a'));   //|=意思是位或运行,即将hash的二进制与|=后数字进行或运算结果赋值给hash
        for(int j = 0;j < arrayB.length;j++){
            if((hash & (1 << (arrayB[j] - 'a'))) == 0){      //进行与运算,即当A中不包含arrayB[j]字符时
                result = false;
                return result;
            }
        }
        return result;
    }
    
    public static void main(String[] args){
        StringContain test = new StringContain();
        String A = "abcd";
        String B = "aab";  
        if(test.placeContain(A, B))
            System.out.println("使用位运算法得到结果:A字符串包含B字符串");
        else
            System.out.println("使用位运算法得到结果:A字符串不包含B字符串");   
    }
}

运行结果:

使用位运算法得到结果:A字符串包含B字符串
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/184276.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SpringBoot2-[SpringBoot优缺点、微服务理解、版本仲裁]

    SpringBoot2-[SpringBoot优缺点、微服务理解、版本仲裁]??‍?博主介绍:大家好,我是芝士味的椒盐,一名在校大学生,热爱分享知识,很高兴在这里认识大家??擅长领域:Java、大数据、运维、电子??如果本文章各位小伙伴们有帮助的话,?关注+??点赞+?评论+?收藏,相应的有空了我也会回访,互助!!!?另本人水平有限,旨在创作简单易懂的文章,在文章描述时如有错,恳请各位大佬指正,在此感谢!!!文章目录Spring.ioSpring5重大升级SpringBoot优点SpringBoot缺点微服务SpringBoot官方文档Maven设置SpringBo..

    2022年9月26日
    2
  • 复试题–smith数

    复试题–smith数

    2021年5月19日
    107
  • touchesBegan:(NSSet*)touches withEvent:(UIEvent *)event使用

    touchesBegan:(NSSet*)touches withEvent:(UIEvent *)event使用iOSProgramming–触摸事件处理(2)        在上一篇《iOSProgramming–触摸事件处理(1)》中了解触摸、事件和响应者之后,接下去学习如何处理用户的触摸事件。首先触摸的对象是视图,而视图的类UIView继承了UIRespnder类,但是要对事件作出处理,还需要重写UIResponder类中定义的事件处理函数。根据不通的触摸状态,程序会调用相应的处理

    2022年7月25日
    7
  • Eric6安装问题

    最近开始学习python,一开始用的开发环境是IDLE,这个开发环境适合新手,安装比较简单,对初学者来说也够使用。但是最近又发现了一个开发环境Eric6,使用起来更加方便,但是安装比较麻烦。下面说说安装步骤:安装环境:win764位python2.7网址:https://www.python.org/PyQt4网址:https://riverbankcomputing.co

    2022年4月8日
    108
  • Unity Cutout材质 实现网格效果[通俗易懂]

    Unity Cutout材质 实现网格效果[通俗易懂]Cutout????效果????贴图准备????材质制作????效果????如图所示铁丝网不是模型只是一张128*128的贴图制作的材质,这样可以极大的降低模型面数制作也很速度!????贴图准备????ps中制作一张128*128尺寸带透明通道的图,如下所示:????材质制作????设置RenderingMode为Cutout模式,并且把贴图放到Albedo槽中????可以调节Tiling属性增加或减少网格密度…

    2022年9月23日
    5
  • Oracle 11g 的PL/SQL函数结果缓存

    Oracle 11g 的PL/SQL函数结果缓存

    2022年1月12日
    47

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号