这道题贪心错误:直接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. Java Embeded 包 与各个架构之间的关系

    Oracle Java Embedded Suite 7.0 for Linux x86        V37917-01.zip        Oracle Java Embedded Suite ...

  2. Luogu5307 [COCI2019] Mobitel 【数论分块】【递推】

    题目分析: 对于向上取整我们总有,$\lceil \frac{\lceil \frac{n}{a} \rceil}{b} \rceil = \lceil \frac{n}{a*b} \rceil$这个 ...

  3. nodejs中使用mongodb

    /** * 使用mongodb存储数据 * 1 首先安装mongodb nodejs插件 npm install mongodb --save-dev * 2 安装express (非必须) * * ...

  4. Visual Studio中找不到.Net Core SDK

    在win 7 64位上安装了.Net Core 2.1 x86 SDK后,又卸载重新安装了.Net Core 3/2 x64 SDK.结果在VS中新建项目时没有.Net Core 3.1 SDK. 在 ...

  5. vue的data里面的值是数组时,在更改其某一项的时候,怎么触发视图的重新渲染?

    1. 设置对象或数组的值:Vue.set(target,key,value) :2.删除对象或数组中元素: Vue.delete ( target,key) ;3. 数组对象直接修改属性,可以触发视图 ...

  6. mysql把A表数据插入到B表数据的几种方法

    web开发中,我们经常需要将一个表的数据插入到另外一个表,有时还需要指定导入字段,设置只需要导入目标表中不存在的记录,虽然这些都可以在程序中拆分成简单sql来实现,但是用一个sql的话,会节省大量代码 ...

  7. [转]大牛们是怎么阅读 Android 系统源码的

    转自:http://www.zhihu.com/question/19759722 由于工作需要大量修改framework代码, 在AOSP(Android Open Source Project)源 ...

  8. Xcode11.1 踩坑备忘录

    Xcode11.1 踩坑备忘录(mac系统10.15) 1 .环信ChatDemo2.0报错 这是环信ChatDemo2.0报错 NSInteger numberOfBeforeSection = [ ...

  9. 从客户发送http请求到服务器返回http之间发生了什么

    由于我知识有限,可能会有模糊或者错误的地方,欢迎讨论与指正. 1.浏览器发出http请求 当用户访问一个url时,浏览器便会开始生成一个http请求. 首先获取http请求中所需要的参数,如url,c ...

  10. mycat-rule

    <?xml version="1.0" encoding="UTF-8"?> <!-- - - Licensed under the Apac ...