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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • eureka本地集群配置eureka集群

    eureka本地集群配置eureka集群eureka本地集群配置eureka集群server:port:4000spring:application:name:eurkea-servereureka:server:enable-self-preservation:false#关闭自我保护(缺省为打开)eviction-interval-timer-in-ms:5000#扫描失效服务的间隔时间(缺省为60*1000ms)client:

    2022年5月24日
    38
  • springmvc之@ResponseBody 和 @RequestBody 注解的区别

    springmvc之@ResponseBody 和 @RequestBody 注解的区别springmvc之@ResponseBody 和 @RequestBody 注解的区别

    2022年4月24日
    38
  • 中华人民共和国国家标准电子计算机机房设计规范_计算机机房建设标准规范

    中华人民共和国国家标准电子计算机机房设计规范_计算机机房建设标准规范第一章总则第1.0.1条为了使电子计算机机房设计确保电子计算机系统稳定可靠运行及保障机房工作人员有良好的工作环境,做到技术先进、经济合理、安全适用、确保质量,制定本规范。第1.0.2条本规范适用于陆地上新建、改建和扩建的主机房建筑面积大于或等于140平方m的电子计算机机房的设计。本规范不适用于工业控制用计算机机房和微型计算机机房。第1.0.3条电子计…

    2022年10月2日
    0
  • 费曼学习法

    费曼学习法费曼学习法我的理解:费曼学习法就是把学好的东西用简洁易懂的语言,传授给别人举例:你学完微积分,然后自己去培训班,自己做老师,传授给学生们,并且学生们都能听懂费曼学习法的四个步骤:1.确定目标

    2022年7月28日
    3
  • mysql锁表原因及如何处理_表被锁了还能查询

    mysql锁表原因及如何处理_表被锁了还能查询1、锁表发生在insert update、delete中  2、锁表的原理是数据库使用独占式封锁机制,当执行上面的语句时,对表进行锁住,直到发生commite或者回滚或者退出数据库用户 3、锁表的原因  第一、A程序执行了对tableA的insert,并还未commite时,B程序也对tableA进行insert则此时会发生资源正忙的异常就是锁表 第二、锁表常…

    2022年8月23日
    3
  • Socket tips: UDP Echo service – Server code

    Socket tips: UDP Echo service – Server code

    2021年11月30日
    41

发表回复

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

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