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

字符串字符匹配

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;
}
全部评论

相关推荐

整顿职场的柯基很威猛:这种不可怕,最可怕的是夹在一帮名校里的二本选手,人家才是最稳的。
点赞 评论 收藏
分享
Java抽象带篮子:难蚌,点进图片上面就是我的大头😆
点赞 评论 收藏
分享
评论
4
1
分享
牛客网
牛客企业服务