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!

相关推荐
仰泳的熊猫20 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
无极低码1 天前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发1 天前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
superior tigre1 天前
22 括号生成
算法·深度优先
左左右右左右摇晃1 天前
计算机网络笔记整理
笔记·计算机网络
不吃西红柿的851 天前
[职场] 内容运营求职简历范文 #笔记#职场发展
笔记·职场和发展·内容运营
努力也学不会java1 天前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎1 天前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
ECT-OS-JiuHuaShan1 天前
朱梁万有递归元定理,重构《易经》
算法·重构