1.两数之和

1.题目描述

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

复制代码
输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。

2.解题思路

直接用暴力解法,两个循环,但是C语言需要注意一些点

3.代码

objectivec 复制代码
int* twoSum(int* nums, int numsSize, int target, int* returnSize) {
    for(int i =0;i<numsSize;i++){
        for(int j=i+1;j<numsSize;j++){
            if(nums[i]+nums[j] ==target){//建立新数组
            int* res = malloc(sizeof(int)*2);
            res[0]=i;
            res[1]=j;
            *returnSize = 2;
            return res;
            }
        }
    }
    *returnSize = 0;
    return NULL;
}

4.代码剖析

int* res = malloc(sizeof(int)*2);

这一句在堆内存中建立了一个大小为2个int类型的空间,不会随着函数运行完后被销毁,其中,res是一个指针变量,存的是地址,具体来说是该数组res的首地址,*res是对该地址解引用,也就是该地址内的数据,同样也是数组第一个数据即res0 = *res,*(res+0) = res0,*(res+1) = res1.

return res;

返回一个指针变量int*,表示返回一个数组的首地址,可以通过该地址对数组内所有的元素进行寻址,即*(res+i) = resi

相关推荐
c++之路1 小时前
C/C++ 全链路编译工具汇总
c语言·开发语言·c++
凡人叶枫2 小时前
Effective C++ 条款02:宁可以编译器替换预处理器
java·linux·c语言·开发语言·c++
周杰伦fans2 小时前
AutoCAD2016经典模式不见了-设置回14版本前的经典工作空间
服务器·c语言·前端
caimouse3 小时前
Reactos 第 5 章 进程与线程 — 5.1 概述
c语言·windows·架构
你疯了抱抱我3 小时前
【STM32】配置vscode+C工具链+Cortex-Debug开发环境,IC:STM32F411CEU6
c语言·vscode·stm32
FFZero14 小时前
[mpv脚本系统] (五) C层系统调用的实现: mpv client通信机制
c语言·音视频
大阳1234 小时前
ARM.9(RGBLCD,PWM)
c语言·开发语言·汇编·单片机·嵌入式硬件·pwm·rgblcd
csdndeyeye4 小时前
从Ctrl+C/V到一键填充:AI投简历工具实测
c语言·开发语言·自动化·秋招·ai助手·网申·ai投简历
某风吾起5 小时前
C语言总结
c语言·开发语言
weixin_447640065 小时前
[GPU运算]cuda调用
c语言·gpu算力