当前位置: 首页 > news >正文

12.15 - 两数之和 两个浮点类型不可以直接判断相等以及解决方案

目录

1.两数之和

a.核心思想

b.思路

c.步骤

2.两个浮点类型不可以直接判断相等以及解决方案

a.例子1

b.例子2

c.解决方案


1.两数之和

1. 两数之和 - 力扣(LeetCode)https://leetcode.cn/problems/two-sum/description/

class Solution { public: vector<int> twoSum(vector<int>& nums, int target) { // 用于存储数值及其索引的哈希表 unordered_map<int, int> mmap; for(int i = 0; i < nums.size(); i++) { // 计算目标值与当前值的差值 int num = target - nums[i]; if(mmap.find(num) != mmap.end()) { // 如果差值存在于哈希表中,返回结果 return {mmap[num], i}; } // 将当前数值及其索引存入哈希表 mmap[nums[i]] = i; } return {}; } };

a.核心思想

利用哈希表(或字典)存储数组元素值及其下标,通过一次遍历快速查找是否存在满足两数之和为目标值的另一个元素。

b.思路

遍历数组,对于每个元素,计算目标值与该元素的差值,查看差值是否在哈希表中,若在则找到答案;若不在则将当前元素值及其下标存入哈希表,继续遍历。

c.步骤

① 初始化一个空的哈希表。

② 遍历数组nums,对于每个元素nums[i]

  • 计算complement = target - nums[i]

  • 检查complement是否在哈希表中,若在则返回[hash[complement], i]

  • 若不在,将nums[i]作为键,i作为值存入哈希表。

③ 遍历结束若未找到则返回空数组(题目假设有答案,此步可省略异常处理)。

2.两个浮点类型不可以直接判断相等以及解决方案

a.例子1

0.1 + 0.2 == 0.3→ 实际计算可能为0.30000000000000004(二进制浮点表示误差),直接判断不等。

b.例子2

1.0 / 3.0 * 3.0 == 1.0→ 除法后乘法可能因舍入误差导致不等于1。

c.解决方案

用误差范围判断,如abs(a - b) < 1e-9(绝对误差)或abs(a - b) / max(|a|, |b|) < 1e-9(相对误差)。

希望这些内容对大家有所帮助!

感谢大家的三连支持!

http://www.cnnetsun.cn/news/73619.html

相关文章:

  • X-TRACK DIY制作全攻略:从零打造个性化GPS自行车码表外壳
  • 火山引擎文档中心上线Qwen-Image-Edit-2509接入指南
  • FLUX.1-dev支持指令微调?多任务学习实践案例分享
  • 6、深入理解Linux USB文件系统:从VFS到usbfs的构建
  • 解决failed to connect to api.anthropic.c错误,转向国产Qwen方案
  • ComfyUI与Cherry Studio协作:打造个性化AI创作空间
  • 终极轨道计算指南:3个实战技巧解析
  • 时区相关的问题,开发如何自测?
  • 城通网盘直链解析神器:三步解锁高速下载新体验
  • 21届智能车赛外延创意:用车载语音指令触发ACE-Step音乐生成
  • 2025年8款AI论文生成器大揭秘,一键极速写超长篇论文,效率提升300%!
  • 还在用留AIGC痕迹的AI写论文?7款免费工具知网维普查重过
  • Wan2.2-T2V-5B模型部署指南:快速搭建你的实时视频生成服务
  • HunyuanVideo-Foley实战教程:使用Git下载并运行视频音效AI
  • 开源不等于免费:ACE-Step商业化路径中GPU算力与Token的定价策略
  • 【直接抄作业】漏洞挖掘典型场景 + 思路(超详细),零基础入门到精通,一篇搞定
  • EasyAdmin8:企业级后台管理系统的完整解决方案
  • VSCode插件助力SD3.5开发:高效调试FP8模型的实用技巧
  • 终极指南:5分钟掌握移动端选择器开发的完整方案
  • Nginx反向代理配置ACE-Step后端服务:保障高并发下的稳定输出
  • 使用MySQL创建数据库数据表等的完整过程
  • FLUX.1-dev模型本地部署教程:从Git Clone到PyTorch安装全流程
  • 从文本到旋律:ACE-Step如何用自然语言生成完整音乐作品
  • 使用HuggingFace镜像网站加速Qwen3-VL-8B模型拉取
  • ComfyUI节点扩展:将Qwen-Image-Edit-2509嵌入图形化界面
  • 城通网盘直链解析:3步实现高速下载的实用指南
  • Qwen3-14B在金融报告自动生成场景的应用实例
  • 实测对比:LLama-Factory与其他微调框架在GPU利用率上的表现差异
  • Editly终极指南:零基础掌握声明式视频编辑
  • Editly容器化部署:告别环境配置困扰的智能视频编辑方案