C语言 | Leetcode C语言题解之第219题存在重复元素II

题目:

题解:

cpp 复制代码
struct HashEntry {
    int key;                  
    int val;
    UT_hash_handle hh;         
};

void hashAddItem(struct HashEntry **obj, int key, int val) {
    struct HashEntry *pEntry;
    pEntry = malloc(sizeof(struct HashEntry));
    pEntry->key = key;
    pEntry->val = val;
    HASH_ADD_INT(*obj, key, pEntry);
} 

struct HashEntry *hashFindItem(const struct HashEntry **obj, int key)
{
    struct HashEntry *pEntry = NULL;
    HASH_FIND_INT(*obj, &key, pEntry);
    return pEntry;
}

void hashEraseItem(struct HashEntry **obj, int key)
{   
    struct HashEntry *pEntry = NULL;
    HASH_FIND_INT(*obj, &key, pEntry);
    if (NULL != pEntry) {
        HASH_DEL(*obj, pEntry);
        free(pEntry);
    } 
}

void hashFreeAll(struct HashEntry **obj)
{
    struct HashEntry *curr, *next;
    HASH_ITER(hh, *obj, curr, next)
    {
        HASH_DEL(*obj,curr);  
        free(curr);      
    }
}

bool containsNearbyDuplicate(int* nums, int numsSize, int k){
    struct HashEntry *cnt = NULL;
    for (int i = 0; i < numsSize; i++) {
        if (i > k) {
            hashEraseItem(&cnt, nums[i - k - 1]);
        }
        struct HashEntry * pEntry = hashFindItem(&cnt, nums[i]);
        if (NULL != pEntry) {
            return true;
        }
        hashAddItem(&cnt, nums[i], 1);
    }
    hashFreeAll(&cnt);
    return false;
}
相关推荐
xsyaaaan19 分钟前
leetcode-hot100-普通数组:53最大子数组和-56合并区间-189轮转数组-238除了自身以外数组的乘积-41缺失的第一个正数
leetcode
阿拉斯攀登27 分钟前
第 2 篇 小白前置知识急救包!RK 安卓驱动开发必备知识点,一篇补全
c语言·嵌入式·rk3568·安卓驱动
客卿1231 小时前
力扣--组合,子集--回溯法的再探索--总结回溯法
java·算法·leetcode
zh路西法1 小时前
【C语言简明教程提纲】(四):结构体与文件定义和操作
android·c语言·redis
_日拱一卒1 小时前
LeetCode(力扣):环形链表
算法·leetcode·链表
做怪小疯子1 小时前
Leetcode刷题——链表就地反转
算法·leetcode·链表
wsoz2 小时前
GCC编译
linux·c语言·嵌入式·gcc
Eward-an2 小时前
高效构建长度为 n 的开心字符串中第 k 小的字符串
python·leetcode
七七肆十九3 小时前
PTA 习题9-1 时间换算
c语言·算法
样例过了就是过了3 小时前
LeetCode热题100 电话号码的字母组合
数据结构·c++·算法·leetcode·dfs