Leetcode_49. 字母异位词分组(c语言)

本题采用排序方法,C语言由自带快排函数,但需要自己写最后一个要素
以下是代码:

/* 49 字母异位词分组 */
/* 字符串比较函数    */
int cntCmp(const void *a, const void *b){
    char *aa = *(char**)a;
    char *bb = *(char**)b;
    int lena = strlen(aa);
    int lenb = strlen(bb);
/* 只有字母异位词会返回0, 其余会返回正负值 */
	//先判断长度
    if(lena != lenb) return lena - lenb;
    int cnt[26] = {0};
    int i;
    //存入字母
    for (i = 0; i < lena; i++){
        cnt[aa[i] - 'a']++;
        cnt[bb[i] - 'a']--;
    }
    //返回字母
    for (i = 0; i < 26; i++){
        if(cnt[i] != 0) return cnt[i];
    }
    return 0;
}
char *** groupAnagrams(char ** strs, int strsSize, int* returnSize, int** returnColumnSizes){
    if(strsSize == 0){
        *returnSize = 0;
        return NULL;
    }
    char ***res = (char***)malloc(sizeof(char**) * strsSize);
    *returnColumnSizes = (int*)malloc(sizeof(int) * strsSize);
    int i = 0;
    int j, k;
    int idx = 0;
    /* 字符串排序, 使字母异位词排到一起 */
    qsort(strs, strsSize, sizeof(strs[0]), cntCmp);
    /* 双指针输出字母异位词 */
    while(i < strsSize){
        j = i + 1;
        while(j < strsSize && cntCmp(strs + i, strs + j) == 0){
            j++;
        }
            //这里j-i如果写为j-1会出现错误。主要是I和1要看清楚
        res[idx] = (char**)malloc(sizeof(char*) * (j - i));
        for(k = i; k < j; k++) {
            res[idx][k - i] = strs[k];
        }
        (*returnColumnSizes)[idx++] = j - i;
        i = j;
    }
    *returnSize = idx;
    return res;

}

通过时间
在这里插入图片描述

主要是为了逐渐弄懂代码,算法题目前写了几十个,不少都是自己写完发现有很大错误,然后照着题解一边写一边分析,现在打算将分析逐渐记录下来,并与大家分享,大家也可以在评论区提出错误。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值