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】的更多相关文章

  1. USACO Section2.1 The Castle 解题报告

    castle解题报告 —— icedream61 博客园(转载请注明出处)--------------------------------------------------------------- ...

  2. USACO Section2.1 Ordered Fractions 解题报告

    frac1解题报告 —— icedream61 博客园(转载请注明出处)---------------------------------------------------------------- ...

  3. USACO Section2.2 Preface Numbering 解题报告 【icedream61】

    preface解题报告----------------------------------------------------------------------------------------- ...

  4. USACO Section2.1 Hamming Codes 解题报告 【icedream61】

    hamming解题报告----------------------------------------------------------------------------------------- ...

  5. USACO Section2.3 Controlling Companies 解题报告 【icedream61】

    concom解题报告------------------------------------------------------------------------------------------ ...

  6. USACO Section2.3 Money Systems 解题报告 【icedream61】

    money解题报告------------------------------------------------------------------------------------------- ...

  7. USACO Section2.3 Zero Sum 解题报告 【icedream61】

    zerosum解题报告----------------------------------------------------------------------------------------- ...

  8. USACO Section2.3 Cow Pedigrees 解题报告 【icedream61】

    nocows解题报告------------------------------------------------------------------------------------------ ...

  9. USACO Section2.3 Longest Prefix 解题报告 【icedream61】

    prefix解题报告------------------------------------------------------------------------------------------ ...

随机推荐

  1. 获取文件绝对路径:__FILE__与$_SERVER[SCRIPT_FILENAME'']的区别

    1.获取路径 (1)__FILE__ 获取某文件在本地目录中的绝对路径,(也就是说,哪个文件执行这行代码,它就获取哪个文件的绝对路径) (2)$__SERVER['SCRIPT_FILENAME'] ...

  2. Altium_Designer如何快速寻找元件和封装

    初学Altium碰到最多的问题就是:不知道元件放在哪个库中.这里我收集了DXP2004常用元件库下常见的元件.使用时,只需在libary中选择相应元件库后,输入英文的前几个字母就可看到相应的元件了.通 ...

  3. 你的 maven 如何使用

    maven把你从痛苦的找包中解脱,让你感觉如此神奇,也让你的项目能够如此之小--功能一 依赖管理  (pom.xml 项目对象模型配置文件) 没有对比就没有伤害 maven让你可以随意增加删除项目的功 ...

  4. java基础 序列化反序列化流 实现Serializable 接口 自动装载序列号到对象文本文件如修改不能反序列化对象文本,除非自定义long型常量 打印流

    package com.swift.baseKnowledge; import java.io.File; import java.io.FileInputStream; import java.io ...

  5. Json数据常用操作

    JSON字符串: var str1 = '{ "name": "cs", "sex": "man" }'; JSON对象 ...

  6. 【树链剖分 ODT】cf1137F. Matches Are Not a Child's Play

    孔爷的杂题系列:LCT清新题/ODT模板题 题目大意 定义一颗无根树的燃烧序列为:每次选取编号最小的叶子节点形成的序列. 要求支持操作:查询一个点$u$在燃烧序列中的排名:将一个点的编号变成最大 $n ...

  7. JAVA / MySql 编程—— 第四章 高级查询(二)

    1.        EXISTS和NOT EXISTS子查询:EXISTS关键字用来检测数数据库对象是否存在.                  ★EXISTS和NOT EXISTS的结果只取决于是否 ...

  8. JZOJ 5913. 林下风气

    Description 里口福因有林下风气,带领全国各地高校掀起了一股AK风,大家都十分痴迷于AK.里口福为了打击大家的自信心,出了一道自以为十分困难的题目.里口福有一棵树,第i个节点上有点权ai,他 ...

  9. Python 编码格式的使用

    编码史 ASCII > Unicode > UTF-8 Unicode支持多语言,UTF-8自动转换长短细节节省空间 在计算机内存中,统一使用Unicode编码,当需要保存到硬盘或者需要传 ...

  10. POJ:2976-Dropping tests(二分平均值)

    Dropping tests Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 15508 Accepted: 5418 Descr ...