鱼C论坛

 找回密码
 立即注册
查看: 1748|回复: 3

[已解决]关于Leecode在线编译刷题

[复制链接]
发表于 2019-7-22 00:20:13 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
/*给定一个整数数组 nums?和一个目标值 target,请你在该数组中找出和为目标值的那?两个?整数,并返回他们的数组下标。

你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。

示例:

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/two-sum
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。*/
#include <stdio.h>
#include <stdlib.h>
int *twoSum(int *nums, int numsSize, int target, int *returnSize)
{
        int i = 0, j = 0, flag = 0;
        returnSize = (int *)malloc(sizeof(int) * 2);
        for (int x = 0; x < numsSize; x++)
        {
                int t = 0;
                for (int y = 0; y < x; y++)
                {
                        if (nums[x] < nums[y])
                        {
                                t = nums[x];
                                nums[x] = nums[y];
                                nums[y] = t;
                        }
                }
        }
        if ((target < nums[0] + nums[1]) || (target > nums[numsSize - 2] + nums[numsSize - 1]))
        {
                printf("超出范围\n");
                returnSize[0] = NULL;
                returnSize[1] = NULL;
        }
        else
        {
                for (i = 0, j = 0; i < numsSize; i++)
                {
                        for (j = numsSize; j >= 0; j--)
                        {
                                if (nums[i] + nums[j] == target)
                                {
                                        flag++;
                                        if (flag > 0)
                                        {
                                                returnSize[0] = i;
                                                returnSize[1] = j;
                                                break;
                                        }
                                }
                        }
                        if (flag > 0)
                        {
                                break;
                        }
                }
                if (flag < 1)
                {
                        printf("NO NUMBER\n");
                        returnSize[0] = 0;
                        returnSize[1] = 0;
                }
        }

        return returnSize;
}

int main(int argc, char const *argv[])
{
        int arr[] = {2, 7, 11, 15};
        int s = sizeof(arr) / sizeof(arr[0]);
        int key = 10;
        int *result;
        result = twoSum(arr, s, key, result);
        printf("(%d , %d)", result[0], result[1]);
        return 0;
}
这段代码我在VScode运行正常

在Leecode在线编译器上一堆错误


solution.c: In function 'twoSum'
Line 23: Char 17: warning: assignment to 'int' from 'void *' makes integer from pointer without a cast [-Wint-conversion]
   returnSize[0] = NULL;
                 ^
Line 24: Char 17: warning: assignment to 'int' from 'void *' makes integer from pointer without a cast [-Wint-conversion]
   returnSize[1] = NULL;
                 ^
solution.c: At top level
Line 74: Char 5: error: conflicting types for 'main'


到底是咋回事

最佳答案
2019-7-22 12:14:27
本帖最后由 Croper 于 2019-7-22 12:16 编辑

你别把main()给一起粘贴上去啊,
leetcode只要你给出要求的函数,别画蛇添足
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-7-22 08:42:25 | 显示全部楼层
C++的编译要求更严格
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-7-22 09:29:48 From FishC Mobile | 显示全部楼层
问题是,我不知道错哪里了-_-||
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-7-22 12:14:27 | 显示全部楼层    本楼为最佳答案   
本帖最后由 Croper 于 2019-7-22 12:16 编辑

你别把main()给一起粘贴上去啊,
leetcode只要你给出要求的函数,别画蛇添足
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-16 21:42

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表