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

利用DeepSeek辅助PuLP求解Advent of Code 2025第10题 电子工厂 第2部分

原题地址 。

前面,DeepSeek用numpy的线性规划没有解答完成。听张泽鹏先生说他用PuLP这个库整数规划解决了。今天也让DeepSeek编一个。

请用PuLP这个库整数规划解决电压按钮问题,不做别的

他给出了如下程序

importreimportpulpdefparse_line_part2(line):"""解析一行数据,返回电压要求和按钮列表(第二部分)"""# 匹配大括号部分match_brace=re.search(r'\{([^}]+)\}',line)ifnotmatch_brace:returnNone,None# 解析电压要求joltage_str=match_brace.group(1)target=[int(x.strip())forxinjoltage_str.split(',')]# 匹配所有圆括号部分buttons=[]pattern=r'\(([^)]+)\)'matches=re.findall(pattern,line)formatchinmatches:# 解析圆括号内的数字nums=[int(x.strip())forxinmatch.split(',')]buttons.append(nums)returntarget,buttonsdefsolve_machine_pulp(target,buttons):"""使用PuLP整数规划求解单个机器的电压配置问题"""n_counters=len(target)n_buttons=len(buttons)# 创建整数规划问题prob=pulp.LpProblem("ButtonPresses",pulp.LpMinimize)# 创建决策变量(每个按钮的按压次数,非负整数)x=pulp.LpVariable.dicts('x',range(n_buttons),lowBound=0,cat='Integer')# 目标函数:最小化总按压次数prob+=pulp.lpSum([x[i]foriinrange(n_buttons)])# 约束条件:每个计数器的总增加量必须等于目标值forcounterinrange(n_counters):# 计算影响该计数器的所有按钮的总贡献total_effect=pulp.lpSum([x[btn_idx]forbtn_idxinrange(n_buttons)ifcounterinbuttons[btn_idx]])prob+=total_effect==target[counter],f"Counter_{counter}_Constraint"# 求解问题prob.solve(pulp.PULP_CBC_CMD(msg=False))# 检查求解状态ifpulp.LpStatus[prob.status]=='Optimal':# 提取解presses_list=[int(pulp.value(x[i]))foriinrange(n_buttons)]total_presses=sum(presses_list)returntotal_presses,presses_list,"求解成功"elifpulp.LpStatus[prob.status]=='Infeasible':return-1,None,"无可行解"else:return-1,None,f"求解失败:{pulp.LpStatus[prob.status]}"defvalidate_solution(target,buttons,presses_list):"""验证解是否正确"""ifpresses_listisNone:returnFalse,Nonem=len(target)current=[0]*mforj,press_countinenumerate(presses_list):ifpress_count>0:foridxinbuttons[j]:current[idx]+=press_countreturncurrent==target,currentdefmain():total_presses=0success_count=0fail_count=0# 读取输入文件withopen('2510-input.txt','r')asf:lines=f.read().strip().splitlines()fori,lineinenumerate(lines):target,buttons=parse_line_part2(line)iftargetisNoneornotbuttons:continuemin_presses,presses_list,message=solve_machine_pulp(target,buttons)ifmin_presses>=0:# 验证解is_valid,calculated=validate_solution(target,buttons,presses_list)ifis_valid:print(f"机器{i+1}:{min_presses}次按压 ({message})")print(f" 按钮按压次数:{presses_list}")print(f" 验证通过:{calculated}=={target}")total_presses+=min_presses success_count+=1else:print(f"机器{i+1}: 验证失败! ({message})")print(f" 尝试解:{presses_list}")print(f" 计算值:{calculated}!= 目标值:{target}")fail_count+=1else:print(f"机器{i+1}: 求解失败 ({message})")fail_count+=1print(f"\n总结:")print(f"成功求解:{success_count}台机器")print(f"失败:{fail_count}台机器")print(f"总最少按压次数:{total_presses}")returntotal_pressesif__name__=="__main__":main()

安装pulp

python3 pip.pyz install pulp --break-system-packages -i https://pypi.tuna.tsinghua.edu.cn/simple

执行

time python3 2510pulp.txt >2510pulp-res.txt real 0m0.783s user 0m0.224s sys 0m0.056s cat 2510pulp-res.txt ... 机器 194: 69 次按压 (求解成功) 按钮按压次数: [0, 16, 25, 25, 1, 2] 验证通过: [41, 51, 41, 43] == [41, 51, 41, 43] 机器 195: 37 次按压 (求解成功) 按钮按压次数: [20, 8, 9] 验证通过: [29, 8, 37, 28, 37] == [29, 8, 37, 28, 37] 总结: 成功求解: 195 台机器 失败: 0 台机器

看来问DeepSeek问题不但要说清楚需求,还要说对工具。

http://www.jsqmd.com/news/75697/

相关文章:

  • Tkinter GUI 编程教程
  • 演讲稿:TRAE SOLO 实战赛——智启Coding 码力全开,让AI为你打造完美旅程
  • 广告创意新工具:基于Wan2.2-T2V-A14B的自动化视频生产
  • 突破模态壁垒:Step-Audio-AQAA端到端语音交互开启人机对话新纪元
  • Mona Sans终极指南:深度解析GitHub可变字体技术原理与实战应用
  • 2025年国内国产挤出滚圆机推荐型号推荐厂家生产厂家哪个品牌好实力厂家十大品牌价格推荐厂家 - 品牌推荐大师1
  • MTK设备解锁终极指南:简单三步绕过bootrom保护
  • 爱美剧Mac客户端:你的智能美剧观影管家
  • 薄膜光学与镀膜技术高清PDF完整学习指南
  • 零成本企业安全监控:开源SOC平台搭建完全指南
  • 终极指南:用Markdown Here轻松美化邮件的完整教程
  • Nuke视觉特效终极指南:200+专业工具一键部署方案
  • Double Take:一站式人脸识别管理平台的终极解决方案
  • TripoSR实战宝典:5秒从图片到专业3D模型的完整攻略
  • 斩获10k star,一款爆火的B站开源客户端!
  • 极客时间:Claude与Cursor智能开发实战
  • Navicat重置工具:macOS试用期延长终极指南 [特殊字符]
  • 【前沿技术解密】:量子Agent为何需要多语言协同?背后架构你不可不知
  • 如何提高微信小游戏分享转化率?试试这7个接口
  • 25、计算机安全事件报告指南
  • Qwen3-8B-MLX-8bit:双模式切换重塑边缘AI部署新标准
  • 2、Linux 系统音频工具与架构全解析
  • 4步出图效率革命:Qwen-Image-Edit-Rapid-AIO V10重构AI图像创作流程
  • 2025深度测评10款降ai率工具:谁是规避检测与保留质量的最优解?(附论文降AI避坑指南)
  • Wan2.2-T2V-A14B模型的错误恢复与断点续生功能
  • Llama-Factory背后的分布式训练引擎技术揭秘
  • Vue文件管理器的终极解决方案:wl-explorer革命性体验
  • LibreCAD:零基础入门专业2D绘图的全能开源解决方案
  • Wan2.2-T2V-A14B是否支持镜头语言指令?实测验证
  • Wan2.2-T2V-A14B如何理解‘风吹树叶’这类物理动词?