| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1195 人关注过本帖
标题:一道dfs的题目,请问一下错在哪里?
只看楼主 加入收藏
青蝶
Rank: 2
等 级:论坛游民
帖 子:160
专家分:51
注 册:2018-2-4
结帖率:92%
收藏
已结贴  问题点数:20 回复次数:4 
一道dfs的题目,请问一下错在哪里?
题目描述
又是一年秋季时,陶陶家的苹果树结了n个果子。陶陶又跑去摘苹果,这次她有一个a公分的椅子。当他手够不着时,他会站到椅子上再试试。
陶陶之前搬凳子,力气只剩下s了。当然,每次摘苹果时都要用一定的力气。陶陶想知道在s<0之前最多能摘到多少个苹果。
现在已知n个苹果到达地上的高度xi,椅子的高度a,陶陶手伸直的最大长度b,陶陶所剩的力气s,陶陶摘一个苹果需要的力气yi,求陶陶最多能摘到多少个苹果。
输入输出格式
输入格式:

第1行:两个数 苹果数n,力气s。
第2行:两个数 椅子的高度a,陶陶手伸直的最大长度b。
第3行~第3+n-1行:每行两个数 苹果高度xi,摘这个苹果需要的力气yi。

输出格式:

只有一个整数,表示陶陶最多能摘到的苹果数。

输入输出样例
输入样例#1: 复制
8 15
20 130
120 3
150 2
110 7
180 1
50 8
200 0
140 3
120 2
输出样例#1: 复制
4
说明
所有数据:n<=5000 a<=50 b<=200 s<=1000
      xi<=280  yi<=100

我的代码:
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;

int n,h[5005][2],height,maximum=0;

void dfs(int i,int s,int count){
    maximum=max(maximum,count);
    if(i>=n) return;
    if((h[i][0]<=height) && (s-h[i][1]>=0)) dfs(i+1,s-h[i][1],count+1);
    dfs(i+1,s,count);
}
   

int main(void){
    int s,a,b,h[5005][2],i;
    scanf("%d %d %d %d",&n,&s,&a,&b);
    for(i=0;i<n;i++)
      scanf("%d %d",&h[i][0],&h[i][1]);
    height=a+b;
    dfs(0,s,0);
    printf("%d\n",maximum);
    return 0;
}
   
搜索更多相关主题的帖子: 苹果 高度 输入 输出 int 
2018-06-20 15:13
wmf2014
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:216
帖 子:2039
专家分:11273
注 册:2014-12-6
收藏
得分:15 
怎么觉着和dfs无关呢?就是一个将小于或等于“凳高+手长”的“消耗力气”从小到大的简单排序吧。

能编个毛线衣吗?
2018-06-20 16:35
星泪成寒
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:6
帖 子:76
专家分:539
注 册:2013-5-19
收藏
得分:5 
被你得代码坑死了,你 h[5005][2] 同时在main函数和 全局都定义了, 结果到dfs函数中使用的全局h里面都是空的,所以每一次都成功.另外,dfs函数最后两行代码应该是if else的关系吧.你代码写的格式太差了
程序代码:
#include <stdio.h>

int main(void)
{
    int i;
    int n, s;
    int a, b;
    int sum = 0;

    struct _apple_parm {
        int xi;
        int yi;
    } apples[5000];
   

    if (scanf("%d %d", &n, &s) != 2) {printf("error\n");return 127;};
    if (scanf("%d %d", &a, &b) != 2) {printf("error\n");return 127;};

    for (i = 0; i < n; i++) {
        if (scanf("%d %d", &apples[i].xi, &apples[i].yi) != 2) {printf("error\n");return 127;};
    }

    i = 0;
    while (s > 0) {
        if ((s >= apples[i].yi) && (apples[i].xi <= (b + a))) {
            ++sum;
            s -= apples[i].yi;
        }
        ++i;
    }   


    printf("%d\n", sum);

    return 0;
}

2018-06-20 17:04
青蝶
Rank: 2
等 级:论坛游民
帖 子:160
专家分:51
注 册:2018-2-4
收藏
得分:0 
回复 3楼 星泪成寒
啊不好意思,那个数组定义重了,因为最开始是写在main函数里面的,后来忘记删了。
不过dfs函数最后不是if和else关系,就是我写的那样,没有else。
2018-06-20 20:05
青蝶
Rank: 2
等 级:论坛游民
帖 子:160
专家分:51
注 册:2018-2-4
收藏
得分:0 
回复 2楼 wmf2014
大佬说的有道理。。
用dfs做,有些数据正确,有些超时了
我改一下试试
2018-06-20 20:07
快速回复:一道dfs的题目,请问一下错在哪里?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025581 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved