USACO--1.3Barn Repair

首先我们肯定可以用一块板就把所有的牛棚覆盖了去,但是我们可以购买m块板,所以我们可以选择去掉m-1段中间没有牛住的连续的牛棚的木板,具体选择哪m-1段?肯定是选择间隔最大的那m-1段了。另外还要注意处理m可能大于总的牛棚数,这时不需要去掉m-1段,只需要去掉c段

代码如下:

/*
ID: 15674811
LANG: C++
TASK: barn1
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<fstream>
using namespace std;

bool cmp(int a,int b)
{
      return a>b;
}

int  main()
{
        ofstream cout("barn1.out");
        ifstream  cin("barn1.in");
        int m,s,c;
        while(cin>>m>>s>>c)
        {
               int a[300],b[300];
               memset(b,0,sizeof(b));
               for(int i=1;i<=c;i++)
                     cin>>a[i];
               sort(a+1,a+c+1);
               int sum=a[c]-a[1]+1;
               for(int i=2;i<=c;i++)
                    b[i-1]=a[i]-a[i-1]-1;
                sort(b+1,b+c,cmp);
                for(int i=1;i<=c&&i<=m-1;i++)
                {
                      sum-=b[i];
                }
                cout<<sum<<endl;
        }
   return 0;
}
时间: 2024-11-08 19:23:44

USACO--1.3Barn Repair的相关文章

USACO 1.3 Barn Repair

Barn Repair It was a dark and stormy night that ripped the roof and gates off the stalls that hold Farmer John's cows. Happily, many of the cows were on vacation, so the barn was not completely full. The cows spend the night in stalls that are arrang

Usaco 1.3.2 修理牛棚(Barn Repair)

  Barn Repair 题意:在一个夜黑风高,下着暴风雨的夜晚,农民约翰的牛棚的屋顶.门被吹飞了. 好在许多牛正在度假,所以牛棚没有住满. 剩下的牛一个紧挨着另一个被排成一行来过夜. 有些牛棚里有牛,有些没有. 所有的牛棚有相同的宽度. 自门遗失以后,农民约翰必须尽快在牛棚之前竖立起新的木板. 他的新木材供应商将会供应他任何他想要的长度,但是供应商只能提供有限数目的木板. 农民约翰想将他购买的木板总长度减到最少. 给出:可能买到的木板最大的数目M(1<= M<=50);牛棚的总数S(1&l

USACO 1.3 Barn Repair(贪心)

这道题同样也是贪心 要使木板总长度最少,就要使未盖木板的长度最大. 我们先用一块木板盖住牛棚,然后,每次从盖住的范围内选一个最大的空隙,以空隙为界将木板分成两块,重复直到分成m块或没有空隙. /* ID:twd30651 PROG:barn1 LANG:C++ */ #include<iostream> #include<fstream> #include<stdlib.h> //#define DEBUG using namespace std; int M; int

【USACO 1.3】Barn Repair

贪心,去掉最大的min(m,c)-1个间隔 /******************************************* TASK: barn1 LANG: C++ Created Time: 2016/9/9 14:36:17 *********************************/ #include<iostream> #include<cstdio> #include<cstring> #include<algorithm> u

USACO Section1.3 Barn Repair 解题报告

barn1解题报告 —— icedream61 博客园(转载请注明出处)------------------------------------------------------------------------------------------------------------------------------------------------[题目] 有一列牛棚,编号从1到S,相邻的牛棚紧挨着(间距为0),每个牛棚长度是一个单位. 其中有C头牛,分别在各自的牛棚中,不存在多个牛挤

usaco Barn Repair

农夫需要将一串大小相等的畜棚盖起来,但是他只能定做M个木板,并不是所有的畜棚都有牛,所以不需要将所有的畜棚都盖起来.问在将所有有牛畜棚都盖起来且只能定做M个木板的情况下,使用的M个木板最少能盖多少个畜棚. 贪心的找出M-1个最大(相连且没有牛的畜棚区间),这些区间总和就是不许要盖住的总和,然后用编号最小的被占畜棚和编号最大的被占畜棚之间的所有畜棚总数减去刚刚得到的不许要盖住的总和就是正解. /* ID: modengd1 PROG: barn1 LANG: C++ */ #include <io

USACO 1.3 Barn Repair (动态规划再写次)

描述 在一个夜黑风高,下着暴风雨的夜晚,farmer John的牛棚的屋顶.门被吹飞了. 好在许多牛正在度假,所以牛棚没有住满. 牛棚一个紧挨着另一个被排成一行,牛就住在里面过夜. 有些牛棚里有牛,有些没有. 所有的牛棚有相同的宽度. 自门遗失以后,farmer John必须尽快在牛棚之前竖立起新的木板. 他的新木材供应商将会供应他任何他想要的长度,但是吝啬的供应商只能提供有限数目的木板. farmer John想将他购买的木板总长度减到最少. 给出:可能买到的木板最大的数目M(1<= M<=

POJ 3253-Fence Repair(贪心)

Fence Repair Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 28417   Accepted: 9229 Description Farmer John wants to repair a small length of the fence around the pasture. He measures the fence and finds that he needs N (1 ≤ N ≤ 20,000)

poj3253 Fence Repair STL优先队列

转载请注明出处:http://blog.csdn.net/u012860063 题目链接:http://poj.org/problem?id=3253 Description Farmer John wants to repair a small length of the fence around the pasture. He measures the fence and finds that he needs N (1 ≤ N ≤ 20,000) planks of wood, each