news 2026/5/28 21:47:59

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
利用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问题不但要说清楚需求,还要说对工具。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/28 8:34:07

Wan2.2-T2V-A14B能否生成带有字幕的视频内容?

Wan2.2-T2V-A14B能否生成带有字幕的视频内容? 在短视频、在线教育和跨文化传播日益依赖自动化内容生成的今天,一个实际而关键的问题浮出水面:AI生成的视频能否“自带”字幕? 更具体地说,像阿里巴巴推出的旗舰级文本到视…

作者头像 李华
网站建设 2026/5/28 19:39:32

DBeaver终极指南:从零开始掌握数据库管理工具

还在为复杂的数据库操作而烦恼吗?DBeaver作为一款强大的开源数据库管理工具,能够帮助你轻松应对各种数据操作需求。本指南将带你从安装配置到高级应用,全面掌握这款数据库管理神器。 【免费下载链接】dbeaver 项目地址: https://gitcode.c…

作者头像 李华
网站建设 2026/5/26 21:57:27

Double Take:一站式人脸识别管理平台的终极解决方案

Double Take:一站式人脸识别管理平台的终极解决方案 【免费下载链接】double-take Unified UI and API for processing and training images for facial recognition. 项目地址: https://gitcode.com/gh_mirrors/dou/double-take 在当今数字化时代&#xff0…

作者头像 李华
网站建设 2026/5/28 12:26:34

Wan2.2-T2V-A14B模型的错误恢复与断点续生功能

Wan2.2-T2V-A14B模型的错误恢复与断点续生功能 在影视预演、广告创意和虚拟内容工厂等高要求场景中,AI生成视频已不再是“能不能做”的问题,而是“能不能稳定地做出来”的问题。一个60秒、720P分辨率、运动自然的AI生成视频,可能需要近一个小…

作者头像 李华
网站建设 2026/5/26 5:34:12

零成本企业安全监控:开源SOC平台搭建完全指南

零成本企业安全监控:开源SOC平台搭建完全指南 【免费下载链接】SOC-OpenSource This is a Project Designed for Security Analysts and all SOC audiences who wants to play with implementation and explore the Modern SOC architecture. 项目地址: https://g…

作者头像 李华
网站建设 2026/5/26 8:25:54

微信小程序任务管理终极指南:weapp-todos完全解析

还在为日常任务管理而烦恼吗?weapp-todos微信小程序为你提供了一站式解决方案。这款轻量级任务清单应用以简洁设计和实用功能为核心,帮助用户高效管理各类待办事项,无论是工作项目还是生活琐事都能轻松应对。 【免费下载链接】weapp-todos 一…

作者头像 李华