博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
woj - 将一个问题转换为背包问题
阅读量:6321 次
发布时间:2019-06-22

本文共 2492 字,大约阅读时间需要 8 分钟。

Problem 1538 - B - Stones II
Time Limit: 1000MS  
Memory Limit: 65536KB  
Total Submit: 428 
Accepted: 64 
Special Judge: No
Description

Xiaoming took the flight MH370 on March 8, 2014 to China to take the ACM contest in WHU. Unfortunately, when the airplane crossing the ocean, a beam of mystical light suddenly lit up the sky and all the passengers with the airplane were transferred to another desert planet.

 

When waking up, Xiaoming found himself lying on a planet with many precious stones. He found that:

 

There are precious stones lying on the planet, each of them has 2 positive values ai and bi. Each time Xiaoming can take the ith of the stones ,after that, all of the stones’ aj (NOT including the stones Xiaoming has taken) will cut down bi units.

 

Xiaoming could choose arbitrary number (zero is permitted) of the stones in any order. Thus, he wanted to maximize the sum of all the stones he has been chosen. Please help him.

Input
The input consists of one or more test cases.
First line of each test case consists of one integer n with 1 <= n <= 1000.
Then each of the following n lines contains two values ai and bi.( 1<= ai<=1000, 1<= bi<=1000)
Input is terminated by a value of zero (0) for n. 
Output
For each test case, output the maximum of the sum in one line.
Sample Input
1
100 100
3
2 1
3 1
4 1
0
Sample Output
100
6
Hint

Source

 

题意 :给你n堆石子,当取走其中的一个后会使剩余所有的石子的费用全部减少当前石子的 b 值,可以选取任意数量的石子,问最终能够取得的最大收益是多少。

思路分析: 这个问题倒着去想比较方便,当取倒数第一个石子时,此时他不会影响任何石子,当取倒数第二个石子时,此时他所能影响的只有倒数第一个,想到这个,dp的转移方程就很明白了, dp[i][j] 表示当枚举到第 i 个石子的时候,此时这个石子作为倒数第 j 个石子的最大收益,则由转移方程

d[i][j]=max(d[i-1][j],d[i-1][j-1]+ai-(j-1)*bi)

在选取的时候,因为当前的情况是会影响后面的,若让这个过程最优,则需要你去贪心一下,对全部的石子排一个序,b值较小的往前面放,b值相同时,a值较大的往前面放。

代码示例:(未测试)

struct node{    int a, b;        bool operator< (const node &v){        if (b == v.b) return a < v.a;        return b > v.b;    }}pre[1005];int dp[1005][1005];int main() {    //freopen("in.txt", "r", stdin);    //freopen("out.txt", "w", stdout);    int n;        while(~scanf("%d", &n) && n){        for(int i = 1; i <= n; i++){            scanf("%d%d", &pre[i].a, &pre[i].b);            }        memset(dp, 0, sizeof(dp));        for(int i = 1; i <= n; i++){            for(int j = 1; j <= i; j++){                dp[i][j] = max(dp[i-1][j], dp[i-1][j-1]+pre[i].a-(j-1)*pre[i].b);            }        }        int ans = 0;        for(int i = 1; i <= n; i++) ans = max(ans, dp[n][i]);                printf("%d\n", ans);    }    return 0;}

 

转载于:https://www.cnblogs.com/ccut-ry/p/9125518.html

你可能感兴趣的文章
[LeetCode] Valid Word Abbreviation 验证单词缩写
查看>>
Shiro 学习笔记(二)——shiro身份验证
查看>>
JMeter 插件 Json Path 解析 HTTP 响应 JSON 数据(转)
查看>>
你不是真正的快乐
查看>>
201707舆情分析系统代码
查看>>
C#在自定义事件里传递自定义数据,使用EventArgs的姿势
查看>>
Memcached常用命令及使用说明
查看>>
Asp.net 前后台操作cookie 实现数据的循环下载
查看>>
MyGeneration学习笔记(9) :在WebService使用dOOdad时,对ToXml/FromXml的一点改进
查看>>
[开发笔记]MySQL & Python经验两则
查看>>
Delphi IDE 之 Object Inspector (对象检查器)
查看>>
关于母版页的按钮事件
查看>>
Using script to submit INV Manager to process MTI/MMTT
查看>>
.net 前台判断
查看>>
【转】.gitignore失效的解决办法
查看>>
中风后遗症当首重治郁——高建忠
查看>>
Linux wget命令
查看>>
QButtonGroup:按钮类的非可视化容器,默认可实现按钮的子类实例的单选。
查看>>
a web-based music player(GO + html5)
查看>>
Python -- 函数对象
查看>>