C语言实现454 4数相加 以及解决本地运行和 leecode端出错的问题

思路 前两个数组和进入MAP 并对同键值的权重进行++]
再将后两个的和的负数 在MAP查找 累积所有键值

在这里插入图片描述

主要是主函数要对全局变量初始化

typedef struct Map
{
    int key;
    int val;//int val=0;结构体内无法赋值
    UT_hash_handle hh;
}myMap;

myMap *Map;
myMap *find(int ikey)
{
    myMap *tmp;

    HASH_FIND_INT(Map,&ikey,tmp);

    return tmp;
}

void insert(int ikey)
{
    myMap *s = find(ikey);
    if(!s)//说明键值不在集合中
    {
        myMap *tmp =(myMap *) malloc(sizeof(myMap));
        tmp->key =ikey;
        tmp->val=1;
        HASH_ADD_INT(Map,key,tmp);//注意这里为key
    }
    else s->val= (s->val)+1;

    return;
}

int fourSumCount(int* nums1, int nums1Size, int* nums2, int nums2Size, int* nums3, int nums3Size, int* nums4, int nums4Size){

    int i,j,asumb,csumd;
    int cnt =0;
    int cnt1;
    

    for(i=0;i<nums1Size;i++)
    {
        for(j=0;j<nums2Size;j++)
        {
            asumb = nums1[i]+nums2[j];
            insert(asumb);
        }
    }
    cnt1 =HASH_COUNT(Map);
    //("cnt是:%d\n",cnt1);


    for(i=0;i<nums3Size;i++)
    {
        for(j=0;j<nums4Size;j++)
        {
            csumd=0-nums3[i]-nums4[j];
            //printf("%d \n",csumd);
            myMap *q=find(csumd);
            if(q) cnt=cnt+(q->val);
        }
    }
return cnt;

}

错误 全局变量需要初始化!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值