USACO Section2.1 Healthy Holsteins 解题报告 【icedream61】
holstein解题报告
------------------------------------------------------------------------------------------------------------------------------------------------
【题目】
你需要给一头奶牛制定最优的喂养计划。
有V种维他命,每天对于每种维他命,牛都有需要达到的指标;
同时你有G种饲料,编号依次为1到G,每种维他命在每种饲料中所蕴含的量都会给你。
请你从中选出N种饲料,在达到指标的前提下让N最小。
【数据范围】
1<=V<=25
1<=每种维他命的指标<=1000
1<=G<=15
【输入格式】
第一行是V,后面V行依次给出1号到V号维他命的指标;
下面一行是G,后面G行依次是G种饲料,每行V个数,分别代表本饲料中各种维他命的含量。
【输出格式】
仅一行,各数用空格隔开。
第一个数是所需的饲料种数N,后面N个数依次是所选饲料的编号。
注意,若有多种方案N相同,则仅输出字典序最小的一组方案。
【输入样例】
4
100 200 300 400
3
50 50 50 50
200 300 200 300
900 150 389 399
【输出样例】
2 1 3
------------------------------------------------------------------------------------------------------------------------------------------------
【分析】
这题做法是枚举。
V种维他命,G份饲料,不妨考虑最大值G=15、V=25。每种饲料枚举取or不取,大约是300,000种情况;每种情况分别用来更新当前最优解,耗时大约不到400。如此可见,本题枚举时间大约在120,000,000,而枚举法常数很小,故而完全可以在1s内完成。
------------------------------------------------------------------------------------------------------------------------------------------------
【总结】
第二次提交AC。第一次犯了点细节错误,把G和V有点弄混的地方。
【吐槽】
这题我严重被自己坑了。。
一开始根本没往枚举法上想,觉得USACO Section2.1的题,怎么也应该有道难题了。。结果想了好长时间没想出做法来,然后一看——这G只有15!这不是完全可以枚举吗……
【再次吐槽】
博文竟然有重名。。今后解题报告标题后面都加上我id,我就不行还有重名-.-
------------------------------------------------------------------------------------------------------------------------------------------------
【代码】
/*
ID: icedrea1
PROB: holstein
LANG: C++
*/ #include <iostream>
#include <fstream>
using namespace std; int V,G;
int v[+],g[+][+];
bool now[+]; int r,s[+];
bool good[+]; bool better()
{
for(int k=;k<=G;++k)
{
if(now[k] && !good[k]) return true;
if(!now[k] && good[k]) return false;
}
}
void Try()
{
int cnt=,sum[+]={};
for(int k=;k<=G;++k)
if(now[k])
{
++cnt;
for(int i=;i<=V;++i) sum[i]+=g[k][i];
}
for(int i=;i<=V;++i)
if(sum[i]<v[i]) return; // 失败
if(cnt<r || cnt==r && better())
{
r=cnt;
for(int k=;k<=G;++k) good[k]=now[k];
}
} void go(int k) //前k组要不要已定
{
if(k==G) { Try(); return; }
++k; go(k);
now[k]=true; go(k); now[k]=false;
} int main()
{
ifstream in("holstein.in");
ofstream out("holstein.out"); in>>V;
for(int i=;i<=V;++i) in>>v[i];
in>>G;
for(int k=;k<=G;++k)
for(int i=;i<=V;++i) in>>g[k][i]; r=G+; go(); out<<r;
for(int k=;k<=G;++k)
if(good[k]) out<<" "<<k;
out<<endl; in.close();
out.close();
return ;
}
USACO Section2.1 Healthy Holsteins 解题报告 【icedream61】的更多相关文章
- USACO Section2.1 The Castle 解题报告
castle解题报告 —— icedream61 博客园(转载请注明出处)--------------------------------------------------------------- ...
- USACO Section2.1 Ordered Fractions 解题报告
frac1解题报告 —— icedream61 博客园(转载请注明出处)---------------------------------------------------------------- ...
- USACO Section2.2 Preface Numbering 解题报告 【icedream61】
preface解题报告----------------------------------------------------------------------------------------- ...
- USACO Section2.1 Hamming Codes 解题报告 【icedream61】
hamming解题报告----------------------------------------------------------------------------------------- ...
- USACO Section2.3 Controlling Companies 解题报告 【icedream61】
concom解题报告------------------------------------------------------------------------------------------ ...
- USACO Section2.3 Money Systems 解题报告 【icedream61】
money解题报告------------------------------------------------------------------------------------------- ...
- USACO Section2.3 Zero Sum 解题报告 【icedream61】
zerosum解题报告----------------------------------------------------------------------------------------- ...
- USACO Section2.3 Cow Pedigrees 解题报告 【icedream61】
nocows解题报告------------------------------------------------------------------------------------------ ...
- USACO Section2.3 Longest Prefix 解题报告 【icedream61】
prefix解题报告------------------------------------------------------------------------------------------ ...
随机推荐
- PDO链式操作——针对关键字出现问题的解决方案
例如: 1.执行一条SQL语句:查询user表中的所有数据,并通过name字段进行降序,通过age进行升序 2. 案例1: 正确的执行语句为:SELECT * FROM user ORDER BY ...
- git(github)常用命令
安装git sudo apt-get install git 显示git版本 git version 显示system属性,对应为/etc/gitconfig文件的内容 git config --sy ...
- SAP CRM WebClient UI和Fiori UI混搭并存
SAP CRM里有个功能可以创建HANA live report,消费HANA Studio里创建的模型. 最后创建好的report长这个样子: 具体创建步骤可以参考我的博客Step by Step ...
- jmter安装配置
一 JMeter 简介 JMeter 它是Apache组织的开放源代码项目,它是现在比较流行的功能和性能测试的工具.JMeter requires a fully compliant JVM 7 or ...
- Leetcode 46 47 Permutation, 77 combination
Permutation class Solution { List<List<Integer>> res = new ArrayList<List<Integer& ...
- Map的嵌套,HDU(1263)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1263 新学的map的嵌套 #include <stdio.h> #include < ...
- 旧文备份:在CANopen网络中通过LSS服务设置节点地址和网络波特率
CANopen专有个子协议用来描述怎样去通过网络设置节点地址和波特率,就是CiA DSP-305,大伙都叫LSS协议,是Layer Setting Services的缩写,不太好翻译,可以叫底层设置服 ...
- 项目部署到自己的IIS上
一般我们只能在本机上才可以开到我们的项目,这个是不需要连网的 如果想让我们的项目在网站中打开,别人也可以看到,就需要把我们的项目部署到服务器上了,输入IP就可以看到我们的项目 发布项目 然后发布网站 ...
- android动画解析(初级)
效果图: ObjectAnimator继承自ValueAnimator的,底层的动画实现机制也是基于ValueAnimator来完成的,因此ValueAnimator仍然是整个属性动画当中最核心的一个 ...
- PXE自动化安装CentOS6/7
服务器为centos7 安装前准备:关闭防火墙和SELINUX 虚拟机准备第二块网卡,设置主机模式,关闭虚拟机网络配置中主机模式的DHCP功能,并设置静态IP nmcli c a con-name e ...