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

字符串字符匹配

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-23 19:33
重庆大学 Java
只学了传统后端,马上去后端实习了,在想要不要学习agent开发相关的。27秋招和26相比难度如何?
我连备胎都不是却还在...:就暑期实习而言,大厂官宣hc 比 26 多,但是我观察看应该低于 26 的,估计秋招也不简单
点赞 评论 收藏
分享
评论
4
1
分享

创作者周榜

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