算法:短字符串中字符是否全部被包含在长字符串中

算法题目:有两个字符串由不同的字母组成,一长一短,长的为A短的为B。设计一个算法,如果所有在B中出现的字符都在A中出现,则返回true,否则返回false。

如下字符串:

    字符串A: abddfdioegdddffsfagj

     字符串B: dofsjadg

    字符串B中每个字符都在A中出现,返回true。

    如下字符串:

    字符串A: aaaabbbbbbdddddd

     字符串B: acc

    字符串B中有字符没在A中出现,返回false。

 答案1:对字符串B中的每个字母在A中都遍历一遍。这个答案很烂,其时间复杂度为O(n*m)

 答案2:设一个哈希表,对字符串A的字符遍历,将每个字符对应的哈希表中的值设为1。然后对B中的字符进行遍历,如果所有字符对应的hash值都为1,则返回true,否则返回false。

    这个答案的时间复杂度是O(m+n),应该是大多数面试者想要的答案,相信大多数人也能想到。

int strInclude(const char *longOne, const char *shortOne)  
{  
    int i, allChar[256] = { 0 };  
    int longLen = strlen(longOne);  
    int shortLen = strlen(shortOne);  
  
    for(i = 0; i < longLen; i++)  
        allChar[longOne[i]] = 1;  
  
    for(i = 0; i < shortLen; i++)   
        if(allChar[shortOne[i]] != 1)  
            break;  
  
    return i == shortLen ? 1 : 0;  
}  

 

转载于:https://www.cnblogs.com/wjw-blog/p/9154961.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值