算法(三十三)

1、判定字符串B是否可由字符串A变换的来  比如  “abccd”    “acbcd” 可以。

public boolean fun(String a, String b){
    int len1 = a.length();
    int len2 = b.length();
    HashMap<String> hm1 = new HashMap<String>;
    HashMap<String> hm2 = new HashMap<String>;
    boolean flag = true;
    
    if(len1 != len2) (return false;}
    for(int i=0; i<len1; i++){
        if(!hm1.containsKey(a.charAt(i))){
            hm1.put(a.charAt(i), 1);
        }else{
            val = hm1.get(a.charAt(i));
            hm1.put(a.charAt(i), ++val);
        }    
    }
    for(int i=0; i<len2; i++){
        if(!hm2.containsKey(b.charAt(i))){
            hm2.put(b.charAt(i), 1);
        }else{
            val = hm2.get(b.charAt(i));
            hm2.put(b.charAt(i), ++val);
        }    
    }
    
    for(int i=0; i<len1; i++){
        if(hm1.containsKey(b.charAt(i)) && (hm1.get(b.charAt(i)) == hm2.get(b.charAt(i)))){
            continue;
        }else{
            flag = false;
            break;
        }    
    }
    return flag;    
}

2.给定形如pattern="aabbc",city="北京 北京 上海 上海 蓬莱"两个字符串,这样的pattern和city之间是匹配的(a=北京,b=上海,c=蓬莱)。规定pattern内的字符属于[a-z],city的城市名必定以空格分隔,给定任意pattern和city,返回它们是否匹配(True/False)

public class test002 {
    private static boolean fun1(String pattern, String city) {
        HashMap<Character, String> hm = new HashMap<>();
        String[] new_city = city.split(" ");
        int len1 = pattern.length();
        int len2 = new_city.length;
        boolean flag = false;
        if(len1 != len2) return false;

        for(int i=0; i<len1; i++){
            hm.put(pattern.charAt(i), new_city[i]);
        }

        for(int i=0; i<len1; i++){
            if(hm.get(pattern.charAt(i)).equals(new_city[i])){
                flag=true;
            }else{
                flag=false;
                break;
            }

        }
        return flag;
    }

    private static boolean fun2(String city, String pattern) {
        HashMap<String, Character> hm = new HashMap<>();
        String[] new_city = city.split(" ");
        int len1 = pattern.length();
        int len2 = new_city.length;
        boolean flag = false;
        if(len1 != len2) return false;

        for(int i=0; i<len1; i++){
            hm.put(new_city[i], pattern.charAt(i));
        }

        for(int i=0; i<len1; i++){
            if(hm.get(new_city[i]).equals(pattern.charAt(i))){
                flag=true;
            }else{
                flag=false;
                break;
            }

        }
        return flag;
    }

    public static void main(String[] args) {
        String pattern= "aabbc";
        String city = "北京 北京 上海 上海 蓬莱";
        boolean flag1 = fun1(pattern, city);
        boolean flag2 = fun2(city, pattern);
        if(flag1 && flag2) System.out.println(true);
        else{
            System.out.println(false);
        }
    }
}

算法 文章被收录于专栏

根据自己所见所闻进行算法归纳总结

全部评论

相关推荐

11-11 17:45
门头沟学院 Java
扶老蟑螂过马路被无证...:1. 技术栈那里把数据结构删了,小中厂用不上,大厂手撕能难死你,linux那里可以考虑删掉,还不如换个git团队协作开发 2.不要使用一些项目不匹配的技术,例如分库分表和你上边的ddd,真正使用ddd的都是【超】大规模,大部分都仍然使用多模块聚合mvc,这样虽然看起来高大上,但是新增了前期协定需求跟后期维护的成本,因为开发中都是选择最适合当起版本的开发方式跟中间件,这样反而会体现你为了学而学(因为可能面试官都不完全熟悉ddd,然后问你你也回答不出深度) 3.项目写了很多的redis使用,为什么技术栈不写上redis 4.项目技术栈跟业务需求高度重合,完全可以整合成一个,然后再去弄一个感兴趣的其他业务或者轮子,或者把上面的一个换下包装 5.奖项自己编一点奖学金,加个四六级,删掉蓝桥杯
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务