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

阅读: 评论:0

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

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

算法题目:有两个字符串由不同的字母组成,一长一短,长的为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;  
}  

 

转载于:.html

本文发布于:2024-01-28 01:01:36,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/17063749023710.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:字符串   算法   字符
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23