【4.10日题解】——字符串哈希(c代码表述)

简介: 【4.10日题解】——字符串哈希(c代码表述)

☘前言☘

今日份水题开始。希望有想要提高的同学跟我们一起来刷题0.0

P3370 【模板】字符串哈希


🧑🏻作者简介:一个从工业设计改行学嵌入式的年轻人

✨联系方式:2201891280(QQ)

⏳全文大约阅读时间: 20min


全文目录

☘前言☘

解题思路

📑写在最后

P1540 [NOIP2010 提高组] 机器翻译


解题思路

随手写一个链式hash就好了,需要注意的是,内存,内存,内存!!!!c语言的精华就是内存管理,我就是个菜鸡。。。记录字符串用于比较的时候一定要新开一端区域,不然的话就是错的!!!!


#include <cstdio>
#include <cstring>
#include <cstdlib>
const int maxn = 49999;
int count = 0;
struct node{
    char *s;
    node *next;
};
node * HashTable[maxn];
void HashInsert(char *str){
    int hashnum = 0,n = 0;
    for(int i = 0;str[i];++i){
        hashnum *= 128;
        hashnum += str[i];
        hashnum %= maxn;
        ++n;
    }
    node *p = HashTable[hashnum];
    while(p){
        if(strcmp(p->s,str) == 0)   return;
        p = p->next;
    }
    ++count;
    p = (node *)malloc(sizeof(node));//头插法
    char *tmp = (char *)malloc(sizeof(char) * (n + 1));
    memset(tmp,0,n+1);
    strcpy(tmp,str);
    p->s = tmp;
    p->next = HashTable[hashnum];
    HashTable[hashnum] = p;
}
int main(){
    int n;
    scanf("%d", &n);
    count = 0;
    memset(HashTable,0,sizeof(HashTable));
    while(n--){
        char s[1509];
        scanf("%s",s);
        HashInsert(s);
    }
    printf("%d\n",count);
    return 0;
}




相关文章
|
存储 C语言
C语言题目的多种解法分享 2之字符串左旋和补充题
C语言题目的多种解法分享 2之字符串左旋和补充题
76 0
|
5月前
|
测试技术 C语言
数据结构学习记录——树习题—Tree Traversals Again(题目描述、输入输出示例、解题思路、解题方法C语言、解析)
数据结构学习记录——树习题—Tree Traversals Again(题目描述、输入输出示例、解题思路、解题方法C语言、解析)
46 1
|
算法 程序员 C语言
全排列思路解析附C语言实现
全排列思路解析附C语言实现
|
存储 C语言
C语言题解——倒置字符串(剑指Offer 第58题)
C语言题解——倒置字符串(剑指Offer 第58题)
95 0
C语言题解——倒置字符串(剑指Offer 第58题)
|
C语言
C语言题解:经典递归题目(斐波那契数列、汉罗塔问题以及青蛙跳台阶问题)
C语言题解:经典递归题目(斐波那契数列、汉罗塔问题以及青蛙跳台阶问题)
157 0
C语言题解:经典递归题目(斐波那契数列、汉罗塔问题以及青蛙跳台阶问题)
|
C语言
C语言经典递归题目 -- 汉诺塔问题
C语言经典递归题目 -- 汉诺塔问题
193 0
C语言经典递归题目 -- 汉诺塔问题
|
C语言
C语言经典递归题目 -- 青蛙跳台阶问题
C语言经典递归题目 -- 青蛙跳台阶问题
167 0
C语言经典递归题目 -- 青蛙跳台阶问题
AcWing 周赛12 3804. 构造字符串(贪心 构造)
AcWing 周赛12 3804. 构造字符串(贪心 构造)
76 0
|
算法 UED
【4.3日题解】——贪心(c代码表述)
【4.3日题解】——贪心(c代码表述)
【4.3日题解】——贪心(c代码表述)