题解 | #设计LRU缓存结构#

设计LRU缓存结构

https://www.nowcoder.com/practice/5dfded165916435d9defb053c63f1e84

int cap;
int used = 0;
typedef struct {
// write code here
    int key;
    int value;
} Solution;

Solution* SolutionCreate(int capacity) {
// write code here
    Solution* obj = (Solution*)malloc(sizeof(Solution) * capacity);
    cap = capacity;
    return obj;
}

int SolutionGet(Solution* obj, int key) {
// write code here
    for(int i = 0; i < used; i++) {
        if(obj[i].key == key) {
            int tempvalue = obj[i].value;
            for(int j = i; j < used - 1; j++) {
                obj[j] = obj[j + 1];
            }
            obj[used - 1].key = key;
            obj[used - 1].value = tempvalue;
            return tempvalue;
        }
    }
    return -1;
}

void SolutionPut(Solution* obj, int key, int value) {
// write code here
    bool found = false;
// 首先判断是否已经存在
    for (int i = 0; i < used; i++) {
        //如果存在,将值更新
        if (obj[i].key == key) {
            found = true;
            for (int j = i; j < used - 1; j++) {
                obj[j] = obj[j + 1];
            }
            obj[used - 1].key = key;
            obj[used - 1].value = value;
            printf("update key %d value %d\n", key, value);
        }
    }
    //如果没有
    if (!found) {
// 如果还有剩余空间
        if (used < cap) {
            Solution new;
            new.key = key;
            new.value = value;
            obj[used] = new;
            used++;
            printf("(1)set key %d value %d\n", key, value);
        } else { // 如果没有剩余空间
            printf("delete key %d value %d\n", obj[0].key, obj[0].value);
            int i = 0;
            for(; i < used - 1; i++) {
                obj[i] = obj[i + 1];
            }
            obj[i].key = key;
            obj[i].value = value;
            printf("(2)set key %d value %d\n", key, value);
        }
    }

}

void SolutionFree(Solution* obj) {
// write code here
    free(obj);
}
/**
 * Your Solution struct will be instantiated and called as such:
 * Solution* obj = SolutionCreate(capacity);
 * int param_1 = SolutionGet(obj, key);
 * SolutionPut(obj, key, value);
 * SolutionFree(obj);
*/

全部评论

相关推荐

ProMonkey2024:5个oc?厉害! 但是有一个小问题:谁问你了?😡我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了(别的帖子偷来的,现学现卖😋)
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-26 18:54
说等下个版本吧的发呆爱好者很贪睡:佬最后去了哪家呀
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务