这道题贪心错误:直接dfs就行,枚举新开一个还是往之前的里面塞

贪心代码(80):

#include<cstdio>
#include<algorithm>
#include<cstdlib>
#include<iostream>
#define N 10500
using namespace std;
int read()
{
int x=0,f=1;
char ch=getchar();
while(ch<'0'||ch>'9'){ if(ch=='-')f=-1;ch=getchar(); }
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
int n,W,ans,wei,len1,len2,tot,c[N];
bool vis[N];
struct node{ int val,id; }a[N],b[N];
bool cmp1(const node &a,const node &b)
{
return a.val>b.val;
}
bool cmp2(const node &a,const node &b)
{
return a.val<b.val;
}
int main()
{
#ifdef yilnr
#else
freopen("climb.in","r",stdin);
freopen("climb.out","w",stdout);
#endif
n=read(); wei=read();
for(int i=1;i<=n;i++)
{
a[i].val=read(); b[i].val=a[i].val;
a[i].id=b[i].id=i;
}
sort(a+1,a+n+1,cmp2);
sort(b+1,b+n+1,cmp1);
while(tot!=n)
{
ans++;
W=wei;
len2=1;
while(W>=b[len2].val && len2<=n)
{
if(!vis[b[len2].id])
{
W-=b[len2].val; vis[b[len2].id]=1; tot++;
}
len2++;
}
for(int i=1;i<=n;i++)c[i]=a[i].val;
len1=upper_bound(c+1 , c+n+1 , W) - c;
len1--;
while(W>=a[len1].val && len1>=1)
{
if(!vis[a[len1].id])
{
W-=a[len1].val; vis[a[len1].id]=1; tot++;
}
len1--;
}
}
printf("%d\n",ans);
fclose(stdin);fclose(stdout);
return 0;
}
/*
5 1996
1
2
1994
12
29
*/

代码:

#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std; int n,m;
int a[50];
int ans,sta[50]; inline void DFS(int opt,int cnt) {
if(cnt >= ans) return ;
if(opt == n + 1) {
ans = min(cnt,ans);
return ;
}
for(int i = 1;i <= cnt;i ++) {
if(sta[i] + a[opt] <= m) {
sta[i] += a[opt];
DFS(opt + 1,cnt);
sta[i] -= a[opt];
}
}
sta[cnt + 1] = a[opt];
DFS(opt + 1,cnt + 1);
sta[cnt + 1] = 0;
} int main() {
freopen("climb.in","r",stdin);
freopen("climb.out","w",stdout); scanf("%d%d",&n,&m);
for(int i = 1;i <= n;i ++)
scanf("%d",&a[i]);
sort(a + 1,a + n + 1,greater<int>());
ans = n; DFS(1,1);
printf("%d",ans); fclose(stdin);
fclose(stdout);
return 0;
}

【csp模拟赛九】--dfs3的更多相关文章

  1. 【csp模拟赛九】--dfs2

    dfs 代码: #include<algorithm> #include<iostream> #include<cstdio> using namespace st ...

  2. 【csp模拟赛九】--dfs

    思路: 这道题可以宽搜,深搜,最短路 代码: #include<cstdio> #include<cstring> #include<iostream> #incl ...

  3. CSP模拟赛游记

    时间:2019.10.5 考试时间:100分钟(连正式考试时间的一半还没有到)题目:由于某些原因不能公开. 由于第一次接触NOIinux系统所以连怎么建文件夹,调字体,如何编译都不知道,考试的前半小时 ...

  4. 【CSP模拟赛】Freda的迷宫(桥)

    题目描述 Freda是一个迷宫爱好者,她利用业余时间建造了许多迷宫.每个迷宫都是由若干房间和走廊构成的,每条走廊都连接着两个不同的房间,两个房间之间最多只有一条走廊直接相连,走廊都是双向通过.  黄昏 ...

  5. CSP模拟赛2游记

    这次由于有课迟到30min,了所以只考了70min. 调linux配置调了5min,只剩下65min了. T1:有点像标题统计,但要比他坑一点,而且我就被坑了,写了一个for(int i=1;i< ...

  6. 【CSP模拟赛】Freda的旗帜

    题目描述  要开运动会了,Freda承担起了制作全校旗帜的工作.旗帜的制作方法是这样的:Freda一共有C种颜色的布条,每种布条都有无数个,你可以认为这些布条的长.宽.厚都相等,只有颜色可能不同.每个 ...

  7. 【csp模拟赛4】基站建设 (station.cpp)

    [题目描述] 小 Z 的爸爸是一位通信工程师,他所在的通信公司最近接到了一个新的通 信工程建设任务,他们需要在 C 城建设一批新的基站. C 城的城市规划做得非常好,整个城市被规整地划分为 8 行 8 ...

  8. 【CSP模拟赛】starway(玄学建边 最小生成树)

    问題描述 小w伤心的走上了 Star way to heaven.   到天堂的道路是一个笛卡尔坐标系上一个n×m的长方形通道(顶点在(0,0))和(n,m)),小w从最左边任意一点进入,从右边任意一 ...

  9. 【CSP模拟赛】Confess(数学 玄学)

    题目描述 小w隐藏的心绪已经难以再隐藏下去了.小w有n+ 1(保证n为偶数)个心绪,每个都包含了[1,2n]的一个大小为n的子集.现在他要找到隐藏的任意两个心绪,使得他们的交大于等于n/2. 输入描述 ...

随机推荐

  1. xorm表结构操作实例

    获取数据库信息 package main import ( "fmt" _ "github.com/go-sql-driver/mysql" "git ...

  2. H5中表格的用法

    1.表格的基本结构: 表格由行和列组成,单元格式表格的最基本单元;每个表格均有若干行,行标签由<tr></tr>定义,每行被分割为若干单元格,由<td></t ...

  3. VUE框架概括+模块语法使用(上)

    vue是什么 官网(https://cn.vuejs.org/) Vue.js是一套构建用户界面的渐进式框架.与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计: Vue 的核心库只关注视图 ...

  4. VS.NET(C#)--1.5_VS菜单功能

    VS菜单功能 文件菜单 1.新建 2.添加 编辑菜单 1.快速查找  ctrl+F 2.快速替换   ctrl+H 3.在文件中查找ctrl+shift+F 4.在文件中替换ctrl+shift+H ...

  5. Python之特征工程-3

    一.什么是特征工程?其实也是数据处理的一种方式,和前面的原始数据不一样的是,我们在原始数据的基础上面,通过提取有效特征,来预测目标值.而想要更好的去得出结果,包括前面使用的数据处理中数据特征提取,新增 ...

  6. swift 有哪些学习资源

    Swift有哪些优秀的学习资源呢? 首先要推荐的当然是官方的资料了. 这个地址里放的是苹果官方为开发者提供的Swfit学习资源:https://developer.apple.com/swift/re ...

  7. node中用的cookie-parser插件设置的max-age,和普通正常设置max-age的计算方式不一样

    在cookie-parser中通过max-age设置的cookie的过期时间是按照毫秒计算的; 在普通设置的时候max-age后面的值是按秒计算的;

  8. 爬虫request库规则与实例

    Request库的7个主要方法: requests.request(method,url,**kwargs) ​ method:请求方式,对应get/put/post等7种: ​ r = reques ...

  9. Hbuilder中配置cmd

    步骤: 1. ①运行——>外部工具——>外部工具 配置2.  新建一个名为cmd(随意命名)的外部工具: 名称:cmd 要执行的命令或文件:C:\Windows\System32\cmd. ...

  10. 100行代码打造属于自己的代理ip池

    经常使用爬虫的朋友对代理ip应该比较熟悉,代理ip就是可以模拟一个ip地址去访问某个网站.我们有时候需要爬取某个网站的大量信息时,可能由于我们爬的次数太多导致我们的ip被对方的服务器暂时屏蔽(也就是所 ...