博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[UVA307]小木棍 Sticks
阅读量:6078 次
发布时间:2019-06-20

本文共 1062 字,大约阅读时间需要 3 分钟。

题目大意:有一堆小木棍,把它们接成相同长度的小木棍,问结果的小木棍的最小长度是多少,多组数据

题解:$dfs$,各种剪枝。
卡点:
C++ Code:

#include 
#include
#include
#define maxn 55const int inf = 0x3f3f3f3f;int n, Min, Max, sum;int cnt[maxn];bool halt;void dfs(int res, int sum, int len, int now) { if (!res) { printf("%d\n", len); halt = true; return ; } if (sum == len) return dfs(res - 1, 0, len, Max); for (int i = now; i >= Min; --i) if (cnt[i] && sum + i <= len) { --cnt[i]; dfs(res, sum + i, len, i); if (halt) return ; ++cnt[i]; if (!sum || sum + i == len) return ; }}int main() { scanf("%d", &n); while (n) { Min = inf, Max = sum = 0, halt = false; __builtin_memset(cnt, 0, sizeof cnt); for (int i = 0, x; i < n; ++i) { scanf("%d", &x); if (x <= 50) { ++cnt[x], sum += x; Min = std::min(x, Min); Max = std::max(x, Max); } } for (int i = Max; i <= sum >> 1; ++i) if (sum % i == 0) dfs(sum / i, 0, i, Max); if (!halt) printf("%d\n", sum); scanf("%d", &n); } return 0;}

 

转载于:https://www.cnblogs.com/Memory-of-winter/p/10326407.html

你可能感兴趣的文章
IDEA使用(1)intellIJ idea 配置 svn
查看>>
WPF 降低.net framework到4.0
查看>>
数据管理DMS 全量SQL诊断:你的SQL是健康的蓝色,还是危险的红色?
查看>>
搭建一个通用的脚手架
查看>>
开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
查看>>
开源磁盘加密软件VeraCrypt教程
查看>>
本地vs云:大数据厮杀的最终幸存者会是谁?
查看>>
阿里云公共镜像、自定义镜像、共享镜像和镜像市场的区别 ...
查看>>
shadowtunnel v1.7 发布:新增上级负载均衡支持独立密码
查看>>
Java线程:什么是线程
查看>>
mysql5.7 创建一个超级管理员
查看>>
【框架整合】Maven-SpringMVC3.X+Spring3.X+MyBatis3-日志、JSON解析、表关联查询等均已配置好...
查看>>
要想成为高级Java程序员需要具备哪些知识呢?
查看>>
带着问题去学习--Nginx配置解析(一)
查看>>
onix-文件系统
查看>>
java.io.Serializable浅析
查看>>
我的友情链接
查看>>
多线程之线程池任务管理通用模板
查看>>
CSS3让长单词与URL地址自动换行——word-wrap属性
查看>>
CodeForces 580B Kefa and Company
查看>>