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!

相关推荐
海清河晏1114 小时前
数据结构 | 单循环链表
数据结构·算法·链表
wuweijianlove8 小时前
算法性能的渐近与非渐近行为对比的技术4
算法
一定要AK8 小时前
Spring 入门核心笔记
java·笔记·spring
_dindong8 小时前
cf1091div2 C.Grid Covering(数论)
c++·算法
AI成长日志8 小时前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
黎阳之光8 小时前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_118 小时前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia8 小时前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
_李小白8 小时前
【OSG学习笔记】Day 38: TextureVisitor(纹理访问器)
android·笔记·学习
wfbcg9 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展