动态规划-选学生
来源:互联网 发布:java分段函数是 编辑:程序博客网 时间:2024/05/17 02:05
题目
有 n 个学生站成一排,每个学生有一个能力值,
从这 n 个学生中按照顺序选取 k 名学生,
要求相邻两个学生的位置编号的差不超过 d,
使得这 k 个学生的能力值的乘积最大,你能返回最大的乘积吗
输入描述:
每个输入包含 1 个测试用例。
每个测试数据的第一行包含一个整数 n (1 <= n <= 50),
表示学生的个数,
接下来的一行,包含 n 个整数,
按顺序表示每个学生的能力值 ai(-50 <= ai <= 50)。
接下来的一行包含两个整数,
k 和 d (1 <= k <= 10, 1 <= d <= 50)。输出描述:
输出一行表示最大的乘积。
思路
- 因为有正有负,所以需要
两个数组
,最大最小,Fmax,Fmin K*N维的,K是选几人,N是总共所少人 - 读数据,动态分配释放内存
Fmax[k][i]
表示以i个人结束,肯定要选,然后已选了k个,下标从0开始和对应人数的要-1k=0
时,表示只选1个人,那么就是i: 0~n-1
总选最大的,初始化过程k: 1~K-1
, 与之前的状态k-1有关,然后最大间隔是D, 所以间隔m: 1~D
,学生位数就是i-m
,当i-m>=0
时Fmax[k][i] = max(Fmax[k][i], max(Fmax[k-1][i-m]*ai[i],Fmin[k-1][i-m]*ai[i]));
同理,Fmin
同样计算,但是是取小的- 不断更新,k++
- 最后就从
Fmax[K-1][0~N]
之间选择个最大的,就是结果
代码
/*有 n 个学生站成一排,每个学生有一个能力值,牛牛想从这 n 个学生中按照顺序选取 k 名学生,要求相邻两个学生的位置编号的差不超过 d,使得这 k 个学生的能力值的乘积最大,你能返回最大的乘积吗输入描述:每个输入包含 1 个测试用例。每个测试数据的第一行包含一个整数 n (1 <= n <= 50),表示学生的个数,接下来的一行,包含 n 个整数,按顺序表示每个学生的能力值 ai(-50 <= ai <= 50)。接下来的一行包含两个整数,k 和 d (1 <= k <= 10, 1 <= d <= 50)。输出描述:输出一行表示最大的乘积。*/#include<iostream>using namespace std;void display(long long ** a, int x, int y){ for(int i = 0;i<x;i++) { for(int j = 0;j<y;j++) cout<<a[i][j]<< " "; cout<<endl; }}// n 个学生中按照顺序选取 k 名学生,// 要求相邻两个学生的位置编号的差不超过 dlong long getMaxAI(int *ai, int K, int D,int N){ long long maxAI = 0; long long **Fmax = new long long *[K]; long long **Fmin = new long long *[K]; for (int x =0;x<K;x++) { Fmax[x] = new long long [N](); //初始化为0;加上() Fmin[x] = new long long [N](); // 初始化,选一个人的时候,K=0,那么没得选,自己 if(x==0) { for (int y = 0;y<N;y++) { Fmax[x][y]=ai[y]; Fmin[x][y]=ai[y]; } } } //display(Fmax,K,N); for(int k = 1;k<K;k++) { for(int i = 0;i<N;i++ ) { for (int m =1;m<=D ; m++ ) { if(i-m>=0) { Fmax[k][i] = max(Fmax[k][i], max(Fmax[k-1][i-m]*ai[i],Fmin[k-1][i-m]*ai[i])); Fmin[k][i] = min(Fmin[k][i], min(Fmax[k-1][i-m]*ai[i],Fmin[k-1][i-m]*ai[i])); } } } //cout<<maxAI<<endl; } for (int n = 0;n<N;n++) { maxAI = max(maxAI,Fmax[K-1][n]); } for (int x =0;x<K;x++) { delete []Fmax[x] ; delete []Fmin[x] ; } delete []Fmax; delete []Fmin; return maxAI;}int main(){ int n; while(cin>>n) { int * ai = new int[n]; for(int i = 0;i<n;i++) { cin>>ai[i]; } int k,d; cin>>k>>d; cout<<getMaxAI(ai,k,d,n)<<endl; delete []ai; } //int ai2[3] = {7,4,7}; //int k2 =2 ,d2 =50, n2=3; //getMaxAI(ai2,k2,d2,n2); return 0;}
0 0
- 动态规划-选学生
- 动态规划!!!动态规划!!!
- 动态规划选讲 8.15
- leetcode 552. Student Attendance Record II 学生出勤记录 + 动态规划DP
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 动态规划
- 第三周项目3-求集合并集
- HDU1128:Self Numbers
- Android中的线程池(一)
- Gitbook简易教程
- 【知识记录】分布式事务解决方案
- 动态规划-选学生
- Gitbook输出为静态网站并启动 (链接中有入门教程)
- 【已解决】Python脚本运行出现语法错误:IndentationError: unindent does not match any outer indentation level
- 关于Ext3.0中按条件查询并重新加载Grid中的数据的实现过程及store.load的分析
- datatables edit 重新定义 创建 修改 删除的 URL路径
- 个人计划
- 第三周项目4-顺序表应用(1)
- Android 使用Messenger实现跨app通信
- tomcat与web程序结构与Http协议与HttpUrlConnection(带答案)