LEETCODE3

法一:记忆化递归

int climbStairsRecursive(int n, int* memo) {if (n <= 2) {return n;}if (memo[n] > 0) {return memo[n];}memo[n] = climbStairsRecursive(n - 1, memo) + climbStairsRecursive(n - 2, memo);return memo[n];
}int climbStairs(int n) {int* memo = (int*)malloc((n + 1) * sizeof(int));if (memo == NULL) {return -1; // 内存分配失败}memset(memo, 0, (n + 1) * sizeof(int));int result = climbStairsRecursive(n, memo);free(memo);return result;
}

法二:动态规划

int climbStairs(int n) {int p = 0, q = 0, r = 1;for (int i = 1; i <= n; ++i) {p = q;q = r;r = p + q;}return r;
}

尽管代码中没有明确地使用一个数组来存储状态,但是动态规划的核心思想仍然被运用了:将问题分解成子问题,利用已经求解过的子问题的解来求解当前问题。

int* intersection(int* nums1, int nums1Size, int* nums2, int nums2Size, int* returnSize) {int hash[1000] = {0}; // 将 hash 数组初始化为 0int* res = (int*)malloc(sizeof(int) * nums1Size); // 根据 nums1 的大小来动态分配内存*returnSize = 0; // 初始化返回数组的大小为 0// 遍历 nums1,将 nums1 中的元素作为 hash 数组的下标,标记出现过的数字for(int i = 0; i < nums1Size; i++) {hash[nums1[i]] = 1;}// 遍历 nums2,如果 nums2 中的元素在 hash 中出现过,则将其添加到返回数组中for(int j = 0; j < nums2Size; j++) {if(hash[nums2[j]] == 1) {res[(*returnSize)++] = nums2[j];hash[nums2[j]] = 0; // 避免重复添加相同的数字,这里很巧妙,添加了一次将hash对应改为0//下一次就算是相同的数字也匹配不了了}}return res;
}

struct hashTable{int key;int val;UT_hash_handle hh;
};int fourSumCount(int* nums1, int nums1Size, int* nums2, int nums2Size, int* nums3, int nums3Size, int* nums4, int nums4Size){struct hashTable*hashtable=NULL;for(int i=0;i<nums1Size;i++){for(int j=0;j<nums2Size;j++){int ikey=nums1[i]+nums2[j];struct hashTable*tmp;HASH_FIND_INT(hashtable,&ikey,tmp);if(!tmp){struct hashTable*tmp=malloc(sizeof(struct hashTable));tmp->key=ikey;tmp->val=1;HASH_ADD_INT(hashtable,key,tmp);}else{tmp->val++;}}}int ans=0;for(int i=0;i<nums3Size;i++){for(int j=0;j<nums4Size;j++){int ikey=-(nums3[i]+nums4[j]);struct hashTable*tmp;HASH_FIND_INT(hashtable,&ikey,tmp);if(tmp){ans+=tmp->val;}}}return ans;
}

先遍历A,B再遍历C,D算法时间复杂度为n的平方,先遍历A,再遍历B,C,D算法时间复杂度是n的三次方,所以我们采用两个for循环比较好

key表示节点的值,val表示这个值在两个数组A,B组合出现过几次

第一个两重for循环先遍历所有A,B数组的所有值,然后记录次数

第二个两重for循环也同样遍历所有C,D所能构成的值,如果其相反数在哈希表中可以找的到的话,就ans加上第一个双层for记录的出现的次数

参考:【学透哈希表,map使用有技巧!LeetCode:454.四数相加II-哔哩哔哩】 https://b23.tv/diFkLwW

 

void HASH_ADD_INT(hh, head, add);

其中:

  • hh 是哈希表中用于链接的哈希结构体的字段名。
  • head 是指向哈希表的指针的名称。
  • add 是要添加到哈希表中的结构体节点的指针。

在您的代码中,HASH_ADD_INT(hashtable, key, tmp); 的作用是将指向结构体节点 tmp 的指针添加到名为 hashtable 的哈希表中。key 是结构体中用于作为键值的整数字段的名称。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/740169.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

代码随想录训练营Day21:● 530.二叉搜索树的最小绝对差 ● 501.二叉搜索树中的众数 ● 236. 二叉树的最近公共祖先

530.二叉搜索树的最小绝对差 题目链接 https://leetcode.cn/problems/minimum-absolute-difference-in-bst/description/ 题目描述 思路 遇到在二叉搜索树上求什么最值&#xff0c;求差值之类的&#xff0c;都要思考一下二叉搜索树可是有序的&#xff0c;要利用好这一特点。…

【More Effective C++】条款24:了解虚函数的成本

每个包含了虚函数的class会包含一个虚函数表&#xff0c;对于C1和C2的虚函数表的结构如下&#xff1a; 非虚函数不会加入到虚函数表中子类中如果对虚函数重写&#xff0c;虚函数表中会覆盖父类的虚函数 C1::~C1()C1::~f1()C1::~f2()C1::~f3() C2::~C2()C2::~f1()C1::~f2()C1:…

Java 拦截器Interceptor详解

1、拦截器概念 先看一下web请求的流程。 &#xff08;1&#xff09;、当浏览器发送一个请求时&#xff0c;请求到达tomcat容器&#xff0c;tomcat容器会区分静态还是动态资源。 &#xff08;2&#xff09;、动态请求会先经过过滤器链filter&#xff0c;直到全部过滤完成之后&am…

MySQL 事务的原理以及长事务的预防和处置

transaction_isolation 隔离级别 读未提交 读提交 视图是在每个 SQL 语句开始执行的时候创建的 可重复读 视图是在事务启动时创建的&#xff0c;整个事务存在期间都用这个视图 串行化…

Claude3系统解读与使用测评

大家好,我是herosunly。985院校硕士毕业,现担任算法研究员一职,热衷于机器学习算法研究与应用。曾获得阿里云天池比赛第一名,CCF比赛第二名,科大讯飞比赛第三名。拥有多项发明专利。对机器学习和深度学习拥有自己独到的见解。曾经辅导过若干个非计算机专业的学生进入到算法…

Character类中的方法总结

Character.isDigit(char ch): 检查指定的字符是否是一个数字。 Character.isWhitespace(char ch): 检查指定的字符是否是一个空白字符。空白字符包括空格、制表符、换页符等。 Character.isUpperCase(char ch): 检查指定的字符是否是大写字母。 Character.isLowerCase(char ch)…

3/12/24交换排序、插入排序、选择排序、归并排序

目录 交换排序 冒泡排序 快速排序 插入排序 直接插入排序 选择排序 简单选择排序 堆排序 归并排序 各种排序的时间复杂度、空间复杂度、稳定性和复杂度 快排真题2016 选排真题2022 排序算法分为交换类排序、插入类排序、选择类排序、归并类排序。 交换排序 交换排…

2024基于协同过滤算法springboot微信订餐小程序项目

项目介绍 基于springboot开发的订餐小程序,用户在微信小程序里面进行注册登录,点餐,收藏,评论等,管理员在后台网页端进行对菜品,分类,订单,用户,角色,评论等进行管理,小程序界面通过协同过滤算法给用户推荐菜品 技术栈 后端:springboot+JPA+Mysql8+redis+maven+…

Django 学习笔记(Day1)

「写在前面」 本文为千锋教育 Django 教程的学习笔记。本着自己学习、分享他人的态度&#xff0c;分享学习笔记&#xff0c;希望能对大家有所帮助。 目录 0 课程介绍 1 Django 快速入门 1.1 Django 介绍 1.2 Django 安装 1.3 创建 Django 项目 1.4 运行 Django 项目 1.5 数据迁…

Linux-gdb调试

文章目录 前言查看&#xff08;显示&#xff09;源代码 list/l运行程序run/r打断点b查看断点删除断点打开/关闭断点逐过程 逐语句查看变量常显示continuefinishuntil修改指定变量退出gdb 前言 GDB&#xff0c;即GNU调试器&#xff08;GNU Debugger&#xff09;&#xff0c;是G…

命令行跑stanford-corenlp

在 https://nlp.stanford.edu/software/stanford-corenlp-4.5.6.zip 下载stanford-corenlp-4.5.6.zip 在 https://stanfordnlp.github.io/CoreNLP/human-languages.html 下载model的jar 然后stanford-corenlp-4.5.6.zip解压&#xff0c;把比如stanford-corenlp-4.5.6-models-…

细粒度IP定位参文27(HGNN):Identifying user geolocation(2022年)

[27] F. Zhou, T. Wang, T. Zhong, and G. Trajcevski, “Identifying user geolocation with hierarchical graph neural networks and explainable fusion,” Inf. Fusion, vol. 81, pp. 1–13, 2022. (用层次图、神经网络和可解释的融合来识别用户的地理定位) 论文地址:…

Matlab工具箱实现相机标定

Matlab工具箱实现张正友相机标定_分别使用蔡氏与张正友标定法完成标定,并与matlab工具箱及(外参)实测结果对照。结-CSDN博客 使用Matlab做相机标定&#xff08;获取相机的内外参数矩阵&#xff09;_matlab相机标定结束后如何显示图片的平移矩阵-CSDN博客 【一文弄懂】张正友标…

QML 控件添加键盘事件

在QML中&#xff0c;可以使用Keys类型来处理键盘事件。以下是一个简单的示例&#xff0c;演示如何在QML控件中添加键盘事件&#xff1a; import QtQuick 2.12 import QtQuick.Window 2.12Window {visible: truewidth: 640height: 480title: qsTr("Hello World")Recta…

基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的常见车型识别系统(Python+PySide6界面+训练代码)

摘要&#xff1a;本文深入探讨了如何应用深度学习技术开发一个先进的常见车型识别系统。该系统核心采用最新的YOLOv8算法&#xff0c;并与早期的YOLOv7、YOLOv6、YOLOv5等版本进行性能比较&#xff0c;主要评估指标包括mAP和F1 Score等。详细解析了YOLOv8的工作机制&#xff0c…

5.Java并发编程—JUC线程池架构

JUC线程池架构 在Java开发中&#xff0c;线程的创建和销毁对系统性能有一定的开销&#xff0c;需要JVM和操作系统的配合完成大量的工作。 JVM对线程的创建和销毁&#xff1a; 线程的创建需要JVM分配内存、初始化线程栈和线程上下文等资源&#xff0c;这些操作会带来一定的时间和…

【ARM架构】讲解

ARM ARM架构&#xff0c;全称为Advanced RISC Machine&#xff08;先进的精简指令集机器&#xff09;&#xff0c;原先称为Acorn RISC Machine&#xff0c;是一种基于精简指令集计算&#xff08;RISC&#xff09;的计算机处理器架构&#xff0c;它被广泛应用在移动设备如智能手…

Linux系统运维脚本:如何查看访问我的linux系统的IP地址,并判断是否有网络攻击?

目 录 一、需求 二、解决思路 三、实现方式 1、抓一定数量的数据包 2、抓取1小时的数据包 3、以小时为周期&#xff0c;周期性的执行抓包1小时 4&#xff0c;抓包分析并输出结果 5&#xff0c;周期性分析并输出结果 &#xff08;1&#xff09;定时…

【基于langchain + streamlit 完整的与文档对话RAG】

本地部署文档问答webdemo 支持 pdf支持 txt支持 doc/docx支持 源文档索引 你的点赞和收藏是我持续分享优质内容的动力哦~ 废话不多说直接看效果 准备 首先创建一个新环境&#xff08;选择性&#xff09; conda create -n chatwithdocs python3.11 conda activate chatwith…

封装的echarts子组件使用watch监听option失效的问题

项目场景&#xff1a; 我在项目里面封装了一个echarts组件&#xff0c;组件接收一个来自外部的option,然后我用了一个watch函数去监听这个option的变化&#xff0c;option变化之后&#xff0c;销毁&#xff0c;然后再新建一个charts表 碎碎念 问题如标题所示&#xff0c;这篇…