| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2293 人关注过本帖
标题:竞赛题,求算法、思路
只看楼主 加入收藏
天胖
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2008-10-8
收藏
 问题点数:0 回复次数:15 
竞赛题,求算法、思路
题目:
    仓库里有一个R行C列的物品架子,各行行高均1米,借助一部梯子,可以拿到任意格子里的物品。每次梯子只能靠字某一列上,这是可以拿这列和它相邻两列的物品。但只能拿到你爬到的高度以下所有格子中的物品(包括爬到的高度)。
    现在你已经清楚将要拿的一些物品的位置(即行列坐标),但为了提高效率,希望尽可能少爬梯子,即爬梯子总高度和最小(拿第一行爬1m,依次类推)。

所给数据:行数R,列数C,物品数N和每个物品的位置坐标(行,列)
输出:最小高度和

补充:
    各个数据都不大,100以内;
    高中联赛水平,请用初级方法^^

我的问题:
1.请问这道题用什么算法?
2.请问这是一个类型的典型题目吗?如果是,是什么类型呢?

[[it] 本帖最后由 天胖 于 2008-10-8 18:26 编辑 [/it]]
搜索更多相关主题的帖子: 竞赛题 算法 思路 
2008-10-08 18:21
天胖
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2008-10-8
收藏
得分:0 
大家可以说说想法呀~
穷举搜索?
2008-10-08 20:18
missiyou
Rank: 5Rank: 5
等 级:贵宾
威 望:16
帖 子:531
专家分:218
注 册:2007-10-9
收藏
得分:0 
晕,不会,
呵呵
。应该是这样,
一行一米。最少爬,那就按1米来吧,
相邻的各二个,用递推算法,步进为2。
这样,看有多少列,算出总和,就是最小高度总和
计算和的。只有一解,典型线性的递推算法。呵呵,瞎说的
2008-10-08 22:27
hellson
Rank: 2
来 自:北京
等 级:新手上路
威 望:4
帖 子:195
专家分:0
注 册:2008-9-1
收藏
得分:0 
动态规划

春了夏了秋冬了,来了来了又来了
相信我的帖子打开都很快,看我头像就知道了
2008-10-09 10:16
天胖
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2008-10-8
收藏
得分:0 
[bo][un]missiyou[/un] 在 2008-10-8 22:27 的发言:[/bo]

晕,不会,
呵呵
。应该是这样,
一行一米。最少爬,那就按1米来吧,
相邻的各二个,用递推算法,步进为2。
这样,看有多少列,算出总和,就是最小高度总和
计算和的。只有一解,典型线性的递推算法。呵呵,瞎 ...


递推么?
如果出现极端值,无法保证最优化解啊。
动态规划?
我水平不够,不清楚这道题目怎么规划= =呵呵

这道题目作为竞赛的第三道(共五道),不应该如此难啊,
看来还是用贪心好了,极端情况忽略吧。。
2008-10-09 19:58
Eastsun
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:32
帖 子:802
专家分:0
注 册:2006-12-14
收藏
得分:0 
用动态规划吧……

My BlogClick Me
2008-10-09 22:01
multiple1902
Rank: 8Rank: 8
等 级:贵宾
威 望:42
帖 子:4881
专家分:671
注 册:2007-2-9
收藏
得分:0 
[bo][un]Eastsun[/un] 在 2008-10-9 22:01 的发言:[/bo]

用动态规划吧……

动规的话感觉状态不好界定,如果记录每一列的高度的话可能需要100维的数组是不是?
2008-10-09 22:18
Eastsun
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:32
帖 子:802
专家分:0
注 册:2006-12-14
收藏
得分:0 
一个长度为100的一维数组足已。
30行代码内可以搞定,如果LZ能提供一些测试数据的话,俺可以写个试试。

My BlogClick Me
2008-10-09 22:39
multiple1902
Rank: 8Rank: 8
等 级:贵宾
威 望:42
帖 子:4881
专家分:671
注 册:2007-2-9
收藏
得分:0 
能否讲讲思路和状态转移方程?
2008-10-10 19:32
Eastsun
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:32
帖 子:802
专家分:0
注 册:2006-12-14
收藏
得分:0 
[bo][un]multiple1902[/un] 在 2008-10-10 19:32 的发言:[/bo]

能否讲讲思路和状态转移方程?


直接给代码吧:
程序代码:
#include<stdio.h>
#include<string.h>
#define MAX 100
#define max2(a,b)   ((a)>(b)?(a):(b))
#define max3(a,b,c) max2(max2(a,b),c)
#define min2(a,b)   ((a)>(b)?(b):(a))

int res[MAX+1];
int solve(int high[],int len){
    int idx;
    res[1] = high[0];
    res[2] = max2(high[0],high[1]);
    res[3] = max3(high[0],high[1],high[2]);
    for(idx = 4;idx <= len;idx ++){
        res[idx] = max3(high[idx-1],high[idx-2],high[idx-3])+res[idx-3];
        res[idx] = min2(res[idx],high[idx-1]+res[idx-1]);
        res[idx] = min2(res[idx],max2(high[idx-1],high[idx-2])+res[idx-2]);
    }
    return res[len];
}

int main(){
    int high[MAX],col,row,size,idx,x,y;
    scanf("%d%d%d",&row,&col,&size);
    memset(high,0,sizeof(high));
    for(idx = 0;idx < size;idx ++){
        scanf("%d%d",&x,&y);
        high[x] = max2(high[x],y);
    }
    printf("%d\n",solve(high,col));
}

其中solve函数不足15行

My BlogClick Me
2008-10-10 20:05
快速回复:竞赛题,求算法、思路
数据加载中...
 
   



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

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