随笔-141  评论-9  文章-3  trackbacks-0

/*
ID: lorelei3
TASK: holstein
LANG: C++
*/


#include 
<fstream>
#include
<stdio.h>
#include
<stdlib.h>
#include
<string.h>

using namespace std;

const int MAX = 30;

int V, G; // V 需要维他命种类数, G可以喂牛的饲料种数

int need[MAX];
int kind[MAX][MAX];
int x[MAX];
int best[MAX];
int y[MAX];
int total=100000000 , num = MAX;

bool check(){
    
int i,j, times=0,to=0;
    memset(y, 
0sizeof(y));
    
for(i=0; i<G; ++i){
        
if(x[i]){
            times
++;
            
for(j=0; j<V; ++j)
                y[j] 
+= kind[i][j];
        }

    }


    
for(i=0; i<V; ++i){
        
if(y[i]<need[i])
            
return false;
        
else
            to 
+=y[i];
    }


    
if(times<num){
        
if(to<total){
            total 
= to;
            
return true;
        }

        
else 
            
return false;
    }
else
        
return false;
}


void dfs(int t){
    
if(t>=G){
        
if(check()){
            num 
= 0;
            
for(int i=0; i<G; ++i){ best[i] = x[i]; num+=best[i]; }
        }

    }
else
        
for(int i=0 ; i<=1++i){
            x[t] 
= i;
            dfs(t
+1);
        }

}


int main(){
    
int i,j;

    ifstream 
in("holstein.in");
    ofstream 
out("holstein.out");

    
in>>V;

    
for(i=0; i<V; ++i)
        
in>>need[i];

    
in>>G;

    
for(i=0; i<G; ++i)
        
for(j=0; j<V; ++j)
            
in>>kind[i][j];

    dfs(
0);

    
char* ch=" ";
    
out<<num<<ch;
    
for(i=0,j=0; i<G; ++i){
        
if(best[i]){
            j
++;
            
if(j==num) ch="";
            
out<<i+1<<ch;
        }

    }

    
out<<endl;
    
return 0;
}

posted on 2010-11-21 00:46 小阮 阅读(158) 评论(0)  编辑 收藏 引用 所属分类: USACO

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理