uva 301 - Transportation
来源:互联网 发布:网络图书馆 编辑:程序博客网 时间:2024/06/02 23:45
点击打开链接
题目意思: 有一辆车从A城市开往B城市,途中有m个站,车上最多的载客人数为n人,每一个站的价格就是终点和起点的差值,现在有k分订单,要求找到这辆车的最大利润
解题思路: 这一题如果我们去搜索站点,那么情况将会非常糟糕,但是如果我么去搜索订单,那么对于每一个订单而言就是取和不取,那么我们就可以知道这个解空间树的每一层就是一个订单,那么我们只要对这个订单编号,然后搜索订单即可。另外我们开一个数组,专门来存储每一个站点当前的人数,注意这里的人数处理,一份订单进来,那么起点---终点前一站都是要加上的,终点下车不用加,还有做dfs之前都是先判断judge函数,最后恢复现场。
代码:
#include <iostream>#include <cstdio>#include <cstring>#include <cstdlib>#include <cmath>#include <cctype>#include <algorithm>using namespace std;const int MAXN = 25;int n, m, d;int num[10]; //记录每一个站点的人数int ans;struct Order {//订单的结构体,存储起点和终点和人数 int start; int end; int number;};Order o[MAXN];//结构体数组//判断当前的所有的站点的人数是否int judge() { for(int i = 0 ; i <= m ; i++){ if(num[i] > n)//如果人数大于n则不满足 return 0; } return 1;}void dfs(int k , int max) { if(ans < max) ans = max; while(k < d){ //如果要选择该订单 for(int i = o[k].start ; i < o[k].end ; i++) num[i] += o[k].number; if(judge()) dfs(k+1 , max+o[k].number*(o[k].end-o[k].start)); //由于之前就加上了人数,所以这里一定要减去人数 for(int i = o[k].start ; i < o[k].end ; i++) num[i] -= o[k].number; ++k;//下一个订单 }}//int main() { while (scanf("%d%d%d%*c", &n, &m, &d)) { if( n == 0 && m == 0 && d == 0)//注意是 0 0 0 结束 break; memset(num, 0, sizeof (num)); ans = 0; for (int i = 0; i < d; i++) scanf("%d%d%d", &o[i].start, &o[i].end, &o[i].number); dfs(0, 0); printf("%d\n", ans); } return 0;}
- UVa 301 - Transportation
- uva 301 - Transportation
- uva 301 - Transportation
- UVa 301 - Transportation
- Uva 301 Transportation
- UVa 301 - Transportation 回溯
- uva 301 Transportation
- UVa 301 - Transportation
- UVA 301 Transportation
- UVA 301 - Transportation
- uva 301 Transportation (DFS)
- uva 301 Transportation
- uva 301 Transportation
- UVa:301 Transportation
- UVa 301 - Transportation
- uva 301 - Transportation
- UVa 301 Transportation
- ( 回溯 )uva 301 - Transportation
- 二叉排序树的应用(基于二叉排序树的个人通信录)
- 16个HTML5 框架、模板以及生成工具
- /$ORACLE_BASE/下没有admin路径
- Javascript undefined vs null
- ios学习---函数的书写
- uva 301 - Transportation
- 20个代码生成软件
- oracle10g创建数据库的方法
- Javascript中出现内存泄漏的主要原因是什么
- PHP 安装包 VC9 VC6 区别是什么
- ExpandableListView 使用方式
- [java]中代码注释问题
- oracle登录方式
- Oracle备份和恢复