题解 | #字符串字符匹配#

字符串字符匹配

http://www.nowcoder.com/practice/22fdeb9610ef426f9505e3ab60164c93

思路

注意不要理解为判断短字符串是否为长字符串的子串
该题时判断是否包含所有字母

  1. 获得短字符串和长字符串
  2. 将长字符串在hash表中对应位置赋值为1,为了后续统计短字符串字符在长字符个数
  3. 统计短字符所在位置的个数
  4. 比较长字符串中短字符串字符所占个数和短字符串本身个数
  5. 如果相同则包含,如果不同则不包含

Answer

#include<stdio.h>
#include<string.h>

int main() {
    char str1[200];
    char str2[200];
    int cnt=0,isStr = 0;
    int hash[200]={0};
    scanf("%s", str1); //短字符
    scanf("%s", str2);

    for (int i = 0; i < strlen(str2); i++) {
        hash[str2[i]] = 1; //将字符串字符所在位置赋值为1;
    }
    for (int i = 0; i < strlen(str1); i++) {
        if(hash[str1[i]]){
            cnt++;//统计短字符所在位置的个数
        }
    }
    if(cnt == strlen(str1)){
        isStr=1;
    }
    if (isStr) {
        printf("true\n");
    } else {
        printf("false\n");
    }
    return 0;
}
全部评论

相关推荐

05-20 18:38
北京大学 Java
点赞 评论 收藏
分享
03-26 13:04
已编辑
电子科技大学 算法工程师
xiaowl:你这个简历“条目上”都比较有深度性,但是实际上面试官又没法很好的评估你是怎么达到很多看上去很厉害的结果的。要避免一些看上去很厉害的包装,比如高效的内存复用策略的表达,如果仅是简单的一些内存共享机制,而且面试上也没有深挖的空间,就不要这样表达。比如,工程化模式本质上可能就是定义了一些abstract class,那也就没特别多值得讲的内容。建议简历上应该侧重那些你花了大量时间和精力解决、研究的问题,不要过分追求“丰富”,而是关注在技术深入度、问题解决能力的表现上。
没有实习经历,还有机会进...
点赞 评论 收藏
分享
评论
4
1
分享

创作者周榜

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