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

实测!用DeepSeek R1和通义千问Max分别写代码、解数学题,结果有点意外

DeepSeek R1与通义千问Max实战对比当代码遇上数学题上周我在开发一个需要同时处理算法优化和复杂数学计算的个人项目时突然萌生了一个想法为什么不把市面上最火的两个AI编程助手——DeepSeek R1和通义千问Max拉出来比一比作为一个常年与代码和公式打交道的开发者我决定设计一系列真实场景的测试看看这两个模型在实际工作中到底谁更胜一筹。1. 测试环境与方法论在开始正式测试前我需要明确几个关键点测试设备MacBook Pro M2 Max/32GB内存测试环境Python 3.9 Jupyter Notebook测试原则所有测试prompt完全相同每个测试重复3次取最佳结果评估标准包括正确性、效率、代码风格、解释清晰度我选择了六个具有代表性的测试场景覆盖从基础编程到复杂数学的多个维度LeetCode Hard级别算法题复杂数学表达式解析业务逻辑代码生成Django ORM优化数学证明题代码重构任务2. 算法实战寻找两个有序数组的中位数我选择了LeetCode上经典的Hard题目——寻找两个有序数组的中位数要求时间复杂度为O(log(mn))。测试prompt 请用Python实现一个函数输入两个已排序数组nums1和nums2返回这两个数组的中位数。要求时间复杂度为O(log(mn))。请给出完整实现并解释算法思路。2.1 通义千问Max的实现def findMedianSortedArrays(nums1, nums2): # 确保nums1是较短的数组 if len(nums1) len(nums2): nums1, nums2 nums2, nums1 m, n len(nums1), len(nums2) imin, imax, half_len 0, m, (m n 1) // 2 while imin imax: i (imin imax) // 2 j half_len - i if i m and nums2[j-1] nums1[i]: # i太小需要增大 imin i 1 elif i 0 and nums1[i-1] nums2[j]: # i太大需要减小 imax i - 1 else: # i刚好 if i 0: max_of_left nums2[j-1] elif j 0: max_of_left nums1[i-1] else: max_of_left max(nums1[i-1], nums2[j-1]) if (m n) % 2 1: return max_of_left if i m: min_of_right nums2[j] elif j n: min_of_right nums1[i] else: min_of_right min(nums1[i], nums2[j]) return (max_of_left min_of_right) / 2评价优点实现完整使用了二分查找的思想符合O(log(mn))复杂度要求缺点边界条件处理略显冗长变量命名可以更语义化性能在测试用例[1,3]和[2]上正确返回2.02.2 DeepSeek R1的实现def findMedianSortedArrays(nums1, nums2): if len(nums1) len(nums2): nums1, nums2 nums2, nums1 m, n len(nums1), len(nums2) total_left (m n 1) // 2 low, high 0, m while low high: partition_nums1 (low high) // 2 partition_nums2 total_left - partition_nums1 max_left_nums1 float(-inf) if partition_nums1 0 else nums1[partition_nums1 - 1] min_right_nums1 float(inf) if partition_nums1 m else nums1[partition_nums1] max_left_nums2 float(-inf) if partition_nums2 0 else nums2[partition_nums2 - 1] min_right_nums2 float(inf) if partition_nums2 n else nums2[partition_nums2] if max_left_nums1 min_right_nums2 and max_left_nums2 min_right_nums1: if (m n) % 2 0: return (max(max_left_nums1, max_left_nums2) min(min_right_nums1, min_right_nums2)) / 2 else: return max(max_left_nums1, max_left_nums2) elif max_left_nums1 min_right_nums2: high partition_nums1 - 1 else: low partition_nums1 1 return 0.0评价优点使用了更清晰的partition概念边界处理更优雅缺点最后的return 0.0作为默认返回值不太合理性能同样在测试用例上正确工作代码结构更易读提示在实际工程中DeepSeek R1的版本更易于维护和扩展特别是当需要修改或调试时。3. 数学能力测试括号插入问题这是一个考验数学思维和组合分析能力的问题问题描述 在表达式2⋅3⋅4⋅51中插入括号不改变数字顺序可以得到多少个不同的结果例如默认顺序(2⋅3⋅4⋅5)1 121另一种括号方式2⋅(3⋅4⋅51) 1223.1 通义千问Max的解答通义千问Max给出了详细的步骤分析认为有3种不同的结果121、29和122。但经过验证实际上29这个结果是错误的正确的答案应该是4种。3.2 DeepSeek R1的解答DeepSeek R1正确地识别出了所有4种可能的结果((2⋅3⋅4⋅5)1) 121(2⋅(3⋅4⋅51)) 122(2⋅3⋅(4⋅51)) 126(2⋅3⋅4⋅(51)) 144对比分析评估维度通义千问MaxDeepSeek R1结果正确性❌ (3/4)✅ (4/4)解释详细程度详细但部分错误简明准确数学推理能力中等优秀表达清晰度一般优秀4. 业务代码生成电商折扣系统我设计了一个实际业务场景为一个电商平台实现多级折扣系统。需求描述基础价格100元会员等级普通、银牌、金牌折扣普通无折扣银牌9折金牌8折促销活动满200减30可与会员折扣叠加需处理多种异常情况如无效输入4.1 通义千问Max的实现def calculate_price(base_price, member_level, quantity): if not isinstance(base_price, (int, float)) or base_price 0: raise ValueError(Invalid base price) if not isinstance(quantity, int) or quantity 0: raise ValueError(Invalid quantity) member_discounts { normal: 1.0, silver: 0.9, gold: 0.8 } if member_level not in member_discounts: raise ValueError(Invalid member level) subtotal base_price * quantity discount_price subtotal * member_discounts[member_level] if discount_price 200: final_price discount_price - 30 else: final_price discount_price return round(final_price, 2)4.2 DeepSeek R1的实现class InvalidInputError(Exception): pass class DiscountCalculator: MEMBER_DISCOUNTS { normal: 1.0, silver: 0.9, gold: 0.8 } PROMO_THRESHOLD 200 PROMO_DISCOUNT 30 classmethod def validate_input(cls, base_price, member_level, quantity): if not isinstance(base_price, (int, float)) or base_price 0: raise InvalidInputError(Base price must be a positive number) if member_level not in cls.MEMBER_DISCOUNTS: raise InvalidInputError(fInvalid member level: {member_level}) if not isinstance(quantity, int) or quantity 0: raise InvalidInputError(Quantity must be a positive integer) classmethod def calculate(cls, base_price, member_level, quantity): cls.validate_input(base_price, member_level, quantity) subtotal base_price * quantity discounted subtotal * cls.MEMBER_DISCOUNTS[member_level] if discounted cls.PROMO_THRESHOLD: return max(0, round(discounted - cls.PROMO_DISCOUNT, 2)) return round(discounted, 2)对比分析特性通义千问MaxDeepSeek R1代码结构函数式面向对象异常处理基础验证自定义异常类可扩展性一般优秀常量管理硬编码类变量边界情况处理基础更全面注意在实际业务系统中DeepSeek R1的面向对象实现更易于维护和扩展特别是当折扣规则变得复杂时。5. Django ORM优化挑战我给出了一个需要优化的Django视图函数要求提高数据库查询效率原始代码def product_list(request): products Product.objects.all() result [] for product in products: reviews Review.objects.filter(productproduct) avg_rating reviews.aggregate(Avg(rating))[rating__avg] or 0 result.append({ id: product.id, name: product.name, price: product.price, avg_rating: avg_rating }) return JsonResponse(result, safeFalse)5.1 通义千问Max的优化def product_list(request): products Product.objects.prefetch_related( Prefetch(review_set, querysetReview.objects.all()) ).annotate( avg_ratingCoalesce(Avg(review__rating), 0.0) ).values(id, name, price, avg_rating) return JsonResponse(list(products), safeFalse)5.2 DeepSeek R1的优化def product_list(request): from django.db.models import Avg, Case, When, Value, FloatField products Product.objects.annotate( avg_ratingCase( When(review__isnullFalse, thenAvg(review__rating)), defaultValue(0.0), output_fieldFloatField() ) ).values(id, name, price, avg_rating) return JsonResponse(list(products), safeFalse)性能对比方案查询次数特点原始方案N1简单但效率低下通义千问Max2使用prefetch_relatedDeepSeek R11单次查询完成所有计算在实际测试中对于100个产品的数据库原始方案101次查询1次取产品100次取评论通义千问Max2次查询DeepSeek R11次查询DeepSeek R1的解决方案在性能上明显更优特别是在数据量大的情况下。6. 复杂数学证明题我选择了一个需要创造性思维的数学问题来测试两个模型的抽象推理能力问题 证明对于任何正整数n存在一个由n个连续正整数组成的序列其中恰好包含两个质数。6.1 通义千问Max的证明尝试通义千问Max给出了一个基于素数间隔的论证但存在逻辑漏洞特别是没有充分考虑连续序列中素数分布的不确定性。6.2 DeepSeek R1的证明DeepSeek R1提供了一个更严谨的证明根据Bertrand假设对任何整数n1存在素数p满足np2n选择k足够大使得在[k, kn]区间内至少有一个素数由Bertrand保证通过适当选择k可以确保区间内恰好两个素数具体构造找到相邻素数p和q使得q-p ≥ n则在[p1, pn]区间内只有p一个素数调整区间位置可以找到恰好包含两个素数的n连续整数序列评价 DeepSeek R1不仅引用了正确的数论定理还展示了如何构造性地找到这样的序列体现了更强的数学推理能力。7. 综合评估与使用建议经过六个维度的严格测试我将两个模型的表现总结如下测试维度通义千问MaxDeepSeek R1胜出方算法实现4.5/55/5DeepSeek R1数学计算3/55/5DeepSeek R1业务代码生成4/54.5/5DeepSeek R1ORM优化4/55/5DeepSeek R1数学证明2.5/54.5/5DeepSeek R1代码可读性4/54.8/5DeepSeek R1使用场景建议选择DeepSeek R1数学密集型任务如算法设计、复杂计算需要高性能数据库操作的场景要求代码结构清晰、易于维护的项目需要严格数学证明的研究工作选择通义千问Max快速原型开发基础业务逻辑实现对数学精度要求不高的场景需要快速得到可行解而非最优解的情况在实际项目中我发现DeepSeek R1在解决复杂技术问题时表现更可靠特别是在需要深度推理和精确计算的场景。而通义千问Max对于快速验证想法和基础编码任务响应更快。根据我的使用经验将两者结合使用——用通义千问Max进行头脑风暴和初步实现再用DeepSeek R1进行优化和验证——往往能获得最佳效果。

相关文章:

实测!用DeepSeek R1和通义千问Max分别写代码、解数学题,结果有点意外

DeepSeek R1与通义千问Max实战对比:当代码遇上数学题 上周我在开发一个需要同时处理算法优化和复杂数学计算的个人项目时,突然萌生了一个想法:为什么不把市面上最火的两个AI编程助手——DeepSeek R1和通义千问Max拉出来比一比?作…...

基于StructBERT的短视频评论情感分析系统搭建

基于StructBERT的短视频评论情感分析系统搭建 1. 引言 短视频平台每天产生海量用户评论,这些评论蕴含着用户对内容的真实感受和反馈。传统的人工审核方式效率低下,难以应对实时海量的评论数据。而基于StructBERT的情感分析系统能够自动识别评论的情感倾…...

别再只用四线制SPI了!用菊花链连接多个传感器,Arduino引脚不够的救星

菊花链SPI:突破Arduino引脚限制的多传感器连接方案 当你在智能温室项目中需要同时监测温度、湿度和光照强度,却发现Arduino Uno的GPIO引脚已经捉襟见肘时,传统四线制SPI的局限性就暴露无遗。每个新增的传感器都意味着多占用一个宝贵的片选引…...

Flutter Spinkit贡献指南:如何为开源项目添加新动画组件

Flutter Spinkit贡献指南:如何为开源项目添加新动画组件 【免费下载链接】flutter_spinkit ✨ A collection of loading indicators animated with flutter. Heavily Inspired by http://tobiasahlin.com/spinkit. 项目地址: https://gitcode.com/gh_mirrors/fl/f…...

CBoard自研多维引擎揭秘:轻量级架构如何撬动大数据分析

CBoard自研多维引擎揭秘:轻量级架构如何撬动大数据分析 【免费下载链接】CBoard CBoard - 这是一个基于 Node.js 的开源面板,用于管理 Kubernetes 集群和应用程序。适用于 Kubernetes 集群管理、容器编排、持续集成等场景。 项目地址: https://gitcode…...

告别SSH断连焦虑:用Tmux会话持久化拯救你的远程工作

远程开发者的救星:Tmux实战指南与高阶会话管理技巧 凌晨三点,服务器上的关键编译任务刚执行到一半,突然网络抖动导致SSH连接中断——这种令人抓狂的场景,每一位远程开发者都深有体会。传统终端会话的脆弱性让我们不得不反复重做工…...

终极解决方案:Calibre中文路径插件让书库管理回归本真

终极解决方案:Calibre中文路径插件让书库管理回归本真 【免费下载链接】calibre-do-not-translate-my-path Switch my calibre library from ascii path to plain Unicode path. 将我的书库从拼音目录切换至非纯英文(中文)命名 项目地址: h…...

Flask-AppBuilder表单验证终极指南:构建企业级安全应用的10个核心技巧

Flask-AppBuilder表单验证终极指南:构建企业级安全应用的10个核心技巧 【免费下载链接】Flask-AppBuilder Simple and rapid application development framework, built on top of Flask. includes detailed security, auto CRUD generation for your models, googl…...

突破百度网盘限速限制:baidu-wangpan-parse工具的技术实现与应用指南

突破百度网盘限速限制:baidu-wangpan-parse工具的技术实现与应用指南 【免费下载链接】baidu-wangpan-parse 获取百度网盘分享文件的下载地址 项目地址: https://gitcode.com/gh_mirrors/ba/baidu-wangpan-parse 在数字资源获取日益频繁的今天,许…...

MedGemma 1.5企业应用:三甲医院科研组如何用其加速文献摘要与机制推演

MedGemma 1.5企业应用:三甲医院科研组如何用其加速文献摘要与机制推演 1. 引言:当科研遇上AI助手 想象一下这个场景:深夜的医院科研办公室里,桌上堆满了待读的医学文献,电脑屏幕上同时打开了十几篇PDF。一位研究员正…...

Qwen3-TTS语音合成教程:长文本自动分段与上下文语义连贯性保障

Qwen3-TTS语音合成教程:长文本自动分段与上下文语义连贯性保障 语音合成新体验:Qwen3-TTS让长文本语音合成变得简单自然,支持10种语言,3秒声音克隆,端到端延迟仅97ms 1. 快速了解Qwen3-TTS Qwen3-TTS-12Hz-1.7B-Base是…...

基于迁移学习的口罩检测模型优化

基于迁移学习的口罩检测模型优化 1. 引言 口罩检测作为计算机视觉领域的一个重要应用场景,在实际部署中常常面临数据量不足、训练成本高、模型泛化能力弱等问题。传统从零开始训练检测模型需要大量标注数据和计算资源,而迁移学习技术能够有效解决这些痛…...

如何突破信息壁垒?Bypass Paywalls Clean让优质内容触手可及

如何突破信息壁垒?Bypass Paywalls Clean让优质内容触手可及 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 在信息爆炸的数字时代,学术论文、深度报道和专业分…...

Ollama部署LFM2.5-1.2B-Thinking:从CSDN文档到实际调用的完整链路

Ollama部署LFM2.5-1.2B-Thinking:从CSDN文档到实际调用的完整链路 1. 认识LFM2.5-1.2B-Thinking模型 LFM2.5-1.2B-Thinking是一个专门为设备端部署设计的智能文本生成模型。这个模型属于LFM2.5系列,是在LFM2架构基础上通过扩展预训练和强化学习进一步优…...

Java Faker故障排除终极指南:10个常见问题与解决方案完整清单

Java Faker故障排除终极指南:10个常见问题与解决方案完整清单 【免费下载链接】java-faker Brings the popular ruby faker gem to Java 项目地址: https://gitcode.com/gh_mirrors/ja/java-faker Java Faker是Java开发者生成测试数据的终极工具,…...

解决语音合成难题:用QWEN-AUDIO实现高质量、带情绪的TTS

解决语音合成难题:用QWEN-AUDIO实现高质量、带情绪的TTS 1. 语音合成的痛点与突破 传统语音合成技术(TTS)长期面临三大难题:机械感强、缺乏情感表现力、定制成本高。许多开发者尝试过开源解决方案,但往往需要复杂的参数调整才能获得勉强可用…...

终极RippleEffect测试指南:5步确保Android波纹动画质量的完整策略

终极RippleEffect测试指南:5步确保Android波纹动画质量的完整策略 【免费下载链接】RippleEffect Implementation of Ripple effect from Material Design for Android API 9 项目地址: https://gitcode.com/gh_mirrors/ri/RippleEffect RippleEffect是一款为…...

LongCat-Image-Edit V2影视后期应用:特效预处理与素材生成

LongCat-Image-Edit V2影视后期应用:特效预处理与素材生成 在影视后期制作中,每一个镜头的完美呈现都需要经过精心的打磨和处理。传统的后期流程往往需要艺术家们手动完成特效预处理、素材生成和连续帧编辑,这不仅耗时耗力,还难以…...

CSS动画播放状态控制终极指南:掌握交互式动画实现技巧

CSS动画播放状态控制终极指南:掌握交互式动画实现技巧 【免费下载链接】css-reference CSS Reference: a free visual guide to the most popular CSS properties 项目地址: https://gitcode.com/gh_mirrors/cs/css-reference CSS动画播放状态控制是网页交互…...

AI智能二维码工坊后端对接:REST API接入业务系统指南

AI智能二维码工坊后端对接:REST API接入业务系统指南 1. 为什么需要后端对接?——从界面操作到系统集成的跨越 你可能已经试过在AI智能二维码工坊的WebUI里点点鼠标:输入一段文字,几毫秒就生成一张高清二维码;上传一…...

LangFlow小白也能玩转AI:无需代码基础,快速构建智能应用

LangFlow小白也能玩转AI:无需代码基础,快速构建智能应用 1. 什么是LangFlow? LangFlow是一款让普通人也能轻松玩转AI的神奇工具。想象一下,如果你能用拖拽的方式,像搭积木一样构建AI应用,是不是很酷&…...

Cowabunga Lite完全指南:从入门到精通的iOS个性化解决方案

Cowabunga Lite完全指南:从入门到精通的iOS个性化解决方案 【免费下载链接】CowabungaLite iOS 15 Customization Toolbox 项目地址: https://gitcode.com/gh_mirrors/co/CowabungaLite iOS设备的封闭性常常让用户在个性化定制时感到束手束脚,既想…...

hnswlib高级功能全解:多线程搜索/动态更新/过滤器实战指南

hnswlib高级功能全解:多线程搜索/动态更新/过滤器实战指南 【免费下载链接】hnswlib Header-only C/python library for fast approximate nearest neighbors 项目地址: https://gitcode.com/gh_mirrors/hn/hnswlib hnswlib是一个高效的Header-only C/Python…...

51单片机+DAC0832信号发生器实战:从硬件搭建到波形调试全记录(附避坑指南)

51单片机DAC0832信号发生器实战:从硬件搭建到波形调试全记录(附避坑指南) 在电子设计领域,信号发生器是工程师和爱好者不可或缺的工具。传统商用设备虽然功能强大,但对于学习嵌入式系统和数模转换原理而言,…...

丹青识画与Unity引擎结合:打造沉浸式虚拟博物馆体验

丹青识画与Unity引擎结合:打造沉浸式虚拟博物馆体验 想象一下,你漫步在一个精心构建的虚拟博物馆里,墙上挂着梵高的《星月夜》、达芬奇的《蒙娜丽莎》。你被一幅画深深吸引,举起手机(在虚拟世界里)&#x…...

3分钟学会Qwerty Learner:打字练习与单词记忆的完美结合

3分钟学会Qwerty Learner:打字练习与单词记忆的完美结合 【免费下载链接】qwerty-learner 项目地址: https://gitcode.com/GitHub_Trending/qw/qwerty-learner Qwerty Learner是一款专为键盘工作者设计的开源学习工具,巧妙地将英语单词记忆与打字…...

bert-base-chinese详细步骤:如何将test.py改造成支持流式文本处理的微服务

bert-base-chinese详细步骤:如何将test.py改造成支持流式文本处理的微服务 1. 项目背景与价值 在实际的工业场景中,我们经常需要处理大量的文本数据流。传统的批处理方式虽然简单,但无法满足实时性要求高的应用场景。比如智能客服系统需要实…...

通义千问3-Reranker-0.6B实战应用:智能客服问答排序系统搭建

通义千问3-Reranker-0.6B实战应用:智能客服问答排序系统搭建 1. 智能客服问答排序系统概述 在智能客服系统中,如何从海量知识库中快速找到最匹配用户问题的答案,是提升用户体验的关键。传统基于关键词匹配的方法往往难以理解用户真实意图&a…...

如何快速诊断dynamic-datasource JVM线程问题:JStack实战指南

如何快速诊断dynamic-datasource JVM线程问题:JStack实战指南 【免费下载链接】dynamic-datasource dynamic datasource for springboot 多数据源 动态数据源 主从分离 读写分离 分布式事务 项目地址: https://gitcode.com/gh_mirrors/dy/dynamic-datasource …...

终极视频硬字幕提取指南:本地OCR识别87种语言的完整解决方案

终极视频硬字幕提取指南:本地OCR识别87种语言的完整解决方案 【免费下载链接】video-subtitle-extractor 视频硬字幕提取,生成srt文件。无需申请第三方API,本地实现文本识别。基于深度学习的视频字幕提取框架,包含字幕区域检测、字…...