洛谷 P2677 超级书架 2 题解
传送门
题目描述
Farmer John最近为奶牛们的图书馆添置了一个巨大的书架,尽管它是如此的大,但它还是几乎瞬间就被各种各样的书塞满了。现在,只有书架的顶上还留有一点空间。 所有N(1 <= N <= 20)头奶牛都有一个确定的身高H_i(1 <= H_i <= 1,000,000 - 好高的奶牛>_<)。设所有奶牛身高的和为S。书架的 高度为B,并且保证1 <= B <= S。 为了够到比最高的那头奶牛还要高的书架顶,奶牛们不得不象演杂技一般,一头站在另一头的背上,叠成一座“奶牛塔”。当然,这个塔的高度,就是塔中所有奶牛的身高之和。为了往书架顶上放东西,所有奶牛的身高和必须不小于书架的高度。 塔叠得越高便越不稳定,于是奶牛们希望找到一种方案,使得叠出的塔在高度不小于书架高度的情况下,高度尽可能小。你也可以猜到你的任务了:写一个程序,计算奶牛们叠成的塔在满足要求的情况下,最少要比书架高多少。
输入输出格式
输入格式:
第1行: 2个用空格隔开的整数:N 和 B * 第2..N+1行: 第i+1行是1个整数:H_i
输出格式:
第1行: 输出1个非负整数,即奶牛们叠成的塔最少比书架高的高度
输入输出样例
输入样例1:
5 16
3
1
3
5
6
输出样例1:
1
说明
输出说明:
我们选用奶牛1、3、4、5叠成塔,她们的总高度为3 + 3 + 5 + 6 = 17。任何方案都无法叠出高度为16的塔,于是答案为1。
思路:
本题有两个做法,\(\Huge{01背包和深搜}\)。深搜入门题,找小的,没找到就继续找,以下代码是深搜。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
#define ll long long
#define R register
using namespace std;
ll n,b,hi[21];
ll vis[21];
int ans=5201314;
void dfs(int sum)
    {
        if(sum>=b)
        {
            ans=min(ans,sum);
            return ;
        }
        for(int i=1;i<=n;i++)
            if(vis[i]==0)
            {
                vis[i]=1;
                sum+=hi[i];
                dfs(sum);
                sum-=hi[i];
                vis[i]=0;
            }
    }
int main()
{
    cin>>n>>b;
    for(int i=1;i<=n;i++)
    {
        cin>>hi[i];
    }
    dfs(0);
    cout<<ans-b<<endl;
    return 0;
}
\(\sum\)
洛谷 P2677 超级书架 2 题解的更多相关文章
- 洛谷 P2677 超级书架 2
		P2677 超级书架 2 题目描述 Farmer John最近为奶牛们的图书馆添置了一个巨大的书架,尽管它是如此的大,但它还是几乎瞬间就被各种各样的书塞满了.现在,只有书架的顶上还留有一点空间. 所有 ... 
- 洛谷P2677 超级书架 2
		题目描述 Farmer John最近为奶牛们的图书馆添置了一个巨大的书架,尽管它是如此的大,但它还是几乎瞬间就被各种各样的书塞满了.现在,只有书架的顶上还留有一点空间. 所有N(1 <= N & ... 
- 洛谷P2676 超级书架 题解
		题目传送门 题目一看就是贪心.C++福利来了:sort. 基本思路就是:要使奶牛最少那么肯定高的奶牛先啦. 直接排序一遍(从高到矮)然后while,搞定! #include<bits/stdc+ ... 
- 洛谷P2676 超级书架
		题目描述 Farmer John最近为奶牛们的图书馆添置了一个巨大的书架,尽管它是如此的大,但它还是几乎瞬间就被各种各样的书塞满了.现在,只有书架的顶上还留有一点空间. 所有N(1 <= N & ... 
- 洛谷——P2676 超级书架
		https://www.luogu.org/problem/show?pid=2676#sub 题目描述 Farmer John最近为奶牛们的图书馆添置了一个巨大的书架,尽管它是如此的大,但它还是几乎 ... 
- 洛谷P1783  海滩防御 分析+题解代码
		洛谷P1783 海滩防御 分析+题解代码 题目描述: WLP同学最近迷上了一款网络联机对战游戏(终于知道为毛JOHNKRAM每天刷洛谷效率那么低了),但是他却为了这个游戏很苦恼,因为他在海边的造船厂和 ... 
- [洛谷P2596] [ZJOI2006]书架
		洛谷题目链接:书架 题目描述 小T有一个很大的书柜.这个书柜的构造有些独特,即书柜里的书是从上至下堆放成一列.她用1到n的正整数给每本书都编了号. 小T在看书的时候,每次取出一本书,看完后放回书柜然后 ... 
- 洛谷P4047 [JSOI2010]部落划分题解
		洛谷P4047 [JSOI2010]部落划分题解 题目描述 聪聪研究发现,荒岛野人总是过着群居的生活,但是,并不是整个荒岛上的所有野人都属于同一个部落,野人们总是拉帮结派形成属于自己的部落,不同的部落 ... 
- 洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈)
		洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1311990 原题地址:洛谷P1155 双栈排序 ... 
随机推荐
- PHP 取网页变量
			$_POST["test"]; $_GET["test"];isset(); if(isset($_GET["yyuid"])) 
- linux下静态库和动态库一些东西
			http://www.cnblogs.com/changefuture/archive/2011/12/22/2297460.html Linux 动态链接库和静态库示例 文件预览 文件目录树如下, ... 
- Timer的缺陷
- Project Browser & Inspector
			[Project Browser] You can drag items from the project structure list to the Favourites and also save ... 
- Hadoop之HDFS(二)HDFS基本原理
			HDFS 基本 原理 1,为什么选择 HDFS 存储数据 之所以选择 HDFS 存储数据,因为 HDFS 具有以下优点: 1.高容错性 数据自动保存多个副本.它通过增加副本的形式,提高容错性. 某一 ... 
- SQLSERVER索引在什么情况下会失效
			索引并不是时时都会生效的,比如以下几种情况,将导致索引失效: 如果条件中有or,即使其中有条件带索引也不会使用(这也是为什么尽量少用or的原因) 注意:要想使用or,又想让索引生效,只能将or条件中的 ... 
- 【NOI2002】荒岛野人
			[题解] 可以枚举m 那么任意两个野人之间有 c[i]+x*p[i]=c[j]+x*p[j] (mod m) 无解,或 x 的最小值<=min(l[i] , l[j]) 化为丢番图方程:(p[ ... 
- 虚拟机ubuntu18.04设置静态IP
			说明: 网关:192.168.8.2 待设置静态IP:192.168.8.25 1.编辑:vi /etc/netplan/01-network-manager-all.yaml 打开以后内容如下: # ... 
- 单机配置tomcat 8 集群
			如何能在集群中的多个节点之间保持数据的一致性,会话(Session)信息是这些数据中最重要的一块. 本文当采用tomcat默认集群配置(<Cluster className="org. ... 
- Solidity开发、测试、部署
			这篇文章很详细的列举了几种方式来开始solidity开发: https://medium.com/@davekaj/solidity-tips-and-tricks-for-beginners-bui ... 
