2026.1.13力扣刷题笔记

题目:

解答:

cpp 复制代码
int** generate(int numRows, int* returnSize, int** returnColumnSizes) {
    int** ret=malloc(sizeof(int*)*numRows);//申请二维数组的行指针
    *returnSize=numRows;//用于告知调用函数此二维数组的行数
    *returnColumnSizes=malloc(sizeof(int)*numRows);//告诉每行的长度step1
    for(int i=0;i<numRows;i++){
        ret[i]=malloc(sizeof(int)*(i+1));//申请每行的空间大小
        (*returnColumnSizes)[i]=i+1;//为每行的长度填写值
        ret[i][0]=ret[i][i]=1;
        for(int j=1;j<i;j++){
            ret[i][j]=ret[i-1][j-1]+ret[i-1][j];
        }
    }return ret;
}
心得:这道题不会,设计到二维数组的构造,注意给出注释的地方。

int* :给你一个地址,你可以直接在那里写东西(调用者已准备好空间)。

int**:给你一个地址的地址**,你需要:

  1. 先在那个地址放一个新的地址(malloc)

  2. 然后用那个新地址访问数组元素

题目:

解答:

cpp 复制代码
int singleNumber(int* nums, int numsSize) {
    int resul=0;
    for(int i=0;i<numsSize;i++){
        resul^=nums[i];
    }
    return resul;
}
心得:题目要求O(n)时间复杂度,所以使用排序再消除行不通。这里使用了异或的手段,"^"消除偶数个,只留下奇数个的数字。

题目:

解答:

cpp 复制代码
int majorityElement(int* nums, int numsSize) {
    int x = nums[0];
    int count = 0;
    for (int i = 0; i < numsSize; i++) {
        if (nums[i] == x)
            count++;
        else
            count--;
        if (count <= 0) {
            x = nums[i];
            count = -count;
        }
    }
    return x;
}
心得:拿到这种题总想到排序,感觉不是好习惯.....这道题应该是王道书上有的,采用的方法就是巧用寻找的数总是多于其他的数,然后遇到目标数就++,否则--,最终哪个更多就是哪个。

明天要开始中等题,fighting!

相关推荐
随意起个昵称2 小时前
【二分做题笔记】组装玩具
笔记·算法
小郭团队2 小时前
1_4_五段式SVPWM (传统算法反正切+DPWM0)算法理论与 MATLAB 实现详解
嵌入式硬件·算法·硬件架构·dsp开发
东方-教育技术博主2 小时前
处理VR头盔眼动数据的论文 领域有哪些分支,经典和前沿算法有啥
算法·vr
客卿1232 小时前
1/14-C语言重排数组
c语言·开发语言·算法
不穿格子的程序员2 小时前
从零开始刷算法——二叉树篇:验证二叉搜索树 + 二叉树中第k小的元素
java·开发语言·算法
老鼠只爱大米2 小时前
LeetCode算法题详解 76:最小覆盖子串
算法·leetcode·双指针·滑动窗口·最小覆盖子串·minwindow
CodeByV2 小时前
【算法题】链表
数据结构·算法
小杨同学492 小时前
【嵌入式 C 语言实战】单链表的完整实现与核心操作详解
后端·算法·架构
Silvia_suu2 小时前
修电脑的笔记
笔记