C语言 | Leetcode C语言题解之第554题砖墙

题目:

题解:

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

int leastBricks(int** wall, int wallSize, int* wallColSize) {
    struct HashTable* cnt = NULL;
    for (int i = 0; i < wallSize; i++) {
        int n = wallColSize[i];
        int sum = 0;
        for (int j = 0; j < n - 1; j++) {
            sum += wall[i][j];
            struct HashTable* tmp;
            HASH_FIND_INT(cnt, &sum, tmp);
            if (tmp == NULL) {
                tmp = malloc(sizeof(struct HashTable));
                tmp->key = sum, tmp->val = 1;
                HASH_ADD_INT(cnt, key, tmp);
            } else {
                tmp->val++;
            }
        }
    }
    int maxCnt = 0;
    struct HashTable *iter, *tmp;
    HASH_ITER(hh, cnt, iter, tmp) {
        maxCnt = fmax(maxCnt, iter->val);
    }
    return wallSize - maxCnt;
}
相关推荐
Jac_kie_層樓4 分钟前
力扣hot100刷题记录(12.2)
算法·leetcode·职场和发展
Molesidy34 分钟前
【C】简易的环形缓冲区代码示例
c语言·开发语言
阿白的白日梦1 小时前
Windows下c/c++编译器MinGW-w64下载和安装
c语言·后端
希望有朝一日能如愿以偿2 小时前
力扣每日一题:统计梯形的数目
算法·leetcode·职场和发展
水饺编程3 小时前
第3章,[标签 Win32] :WM_CREATE 消息的产生
c语言·c++·windows·visual studio
会员果汁3 小时前
双向链式队列-C语言
c语言·数据结构
C语言不精3 小时前
c语言-优雅的多级菜单设计与实现
c语言·开发语言·算法
jyyyx的算法博客4 小时前
LeetCode 面试题 16.22. 兰顿蚂蚁
算法·leetcode
Q741_1474 小时前
C++ 高精度计算的讲解 模拟 力扣67.二进制求和 题解 每日一题
c++·算法·leetcode·高精度·模拟
leoufung4 小时前
LeetCode 98 Validate Binary Search Tree 深度解析
算法·leetcode·职场和发展