一道腾讯面试题

来源:互联网 发布:极有有趣的段子知乎 编辑:程序博客网 时间:2024/06/10 10:15

题目描述:

假设两个字符串中所含有的字符和个数都相同我们就叫这两个字符串匹配,比如:abcda和adabc,由于出现的字符个数都是相同,只是顺序不同,所以这两个字符串是匹配的。要求高效!

我的解法是借用 异或运算,在长度相同的情况下,对所有的字符进行累积异或,由异或的性质,相同的数异或为0,异或满足交换律。时间只有O(n)

代码如下:

[cpp] view plaincopyprint?
  1. /************************************************************************/  
  2. /*  
  3.  
  4.   假设两个字符串中所含有的字符和个数都相同我们就叫这两个字符串匹配, 
  5.   比如:abcda和adabc,由于出现的字符个数都是相同,只是顺序不同, 
  6.  所以这两个字符串是匹配的。要求高效! 
  7.                                                                      */  
  8. /************************************************************************/  
  9.   
  10. #include <IOSTREAM>   
  11. #include <string>   
  12. #include <ASSERT.H>   
  13. using namespace std;  
  14.   
  15. bool isStrMatching(const char* str1,const char* str2)  
  16. {  
  17.     assert( str1!=NULL && str2!=NULL);  
  18.       
  19.     int len1=strlen(str1);  
  20.     int len2=strlen(str2);  
  21.   
  22.     if( len1 != len2 )  
  23.         return false;  
  24.   
  25.     int flag=0,i=0;  
  26.       
  27.     for(;i<len1;i++)  
  28.         flag^=( str1[i]^str2[i] );  
  29.       
  30.     return (flag==0);  
  31. }  
  32.   
  33. void main()  
  34. {  
  35.     char str1[]="abcda";  
  36.     char str2[]="adabc";  
  37.   
  38.     if( isStrMatching(str1,str2) )  
  39.         cout<<"yes.\n";  
  40.     else  
  41.         cout<<"no.\n";  
  42. }  
原创粉丝点击